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PHP 是 世界 上 最 为 流行 的 Web 开发 语言 之 一 。 目 前 学 习 和 关注 PHP 的 人 越 来 越 多 ， 而 
很 多 PHP 的 初学 者 都 苦于 找 不 到 一 本 通俗 易 懂 、 容 易 入 门 和 案例 实用 的 参考 书 。 为 此 ， 作 者 
组 织 有 丰富 经 验 的 开发 人 员 写 作 了 这 本 书 。 


1. 本 书 特色 


(1) 知识 全 面 : 涵盖 了 PHP + MySQL 动态 网 站 开发 的 所 有 知识 点 ， 帮 助 读者 由 浅 入 深 地 
掌握 PHP + MySQL 网 站 开发 方面 的 技能 。 

(2) 图 文 并 茂 : 在 介绍 案例 的 过 程 中 ， 每 一 个 操作 均 有 对 应 的 插图 ， 这 种 图 文 结合 的 方 
式 使 读者 在 学 习 过 程 中 能 够 直观 、 清 晰 地 看 到 操作 的 过 程 及 效果 ， 便 于 更 快 地 理解 和 掌握 。 

(3) 易学 易 用 : 颠覆 传统 “看 ” 书 的 观念 ， 变 成 一 本 能 “操作 ”的 图 书 。 

(4) 案例 丰富 : 把 知识 点 融会 于 系统 的 案例 实 训 中 ， 并 且 结合 经 典 案例 进行 讲解 和 拓 
展 ， 进 而 达到 “ 知 其 然 ， 并 知 其 所 以 然 ” 的 效果 。 

(5) 提示 周到 : 对 读者 在 学 习 过 程 中 可 能 会 遇 到 的 疑难 问题 以 “提示 ”和 “注意 ”等 形 
式 进行 了 说 明 ， 以 免 读 者 在 学 习 的 过 程 中 走 弯路 。 

(6) 超 值 赠送 : 除了 本 书 的 素材 和 结果 外 ， 还 将 赠送 封面 所 述 的 大 量 的 资源 ， 使 读者 可 
以 全 面 掌握 动态 网 站 开发 的 方方面面 的 知识 。 


2. 读者 对 象 

本 书 不 仅 适合 动态 网 站 开发 的 初级 读者 入 门 学 习 ， 还 可 作为 中 、 高 级 用 户 的 参考 手册 。 
书 中 大 量 的 实例 模拟 真实 的 动态 网 站 开发 案例 ， 对 读者 的 工作 有 现实 的 借鉴 作用 。 

3. 作者 团队 


本 书 作者 刘 玉 红 长 期 从 事 网 站 设计 与 开发 工作 ; 另外 ， 胡 同 夫 、 梁 云 亮 、 王 攀登 、 王 婷 
婷 、 陈 伟 光 、 包 慧 利 、 孙 若 淞 、 肖 品 、 王 维 维和 刘海 松 等 人 参与 了 编写 工作 。 

本 书 虽 然 倾注 了 作者 的 努力 ， 但 由 于 水 平 有 限 ， 书 中 难免 有 错漏 之 处 ， 读 者 如 果 遇 到 问 
题 或 有 意见 和 建议 ， 敬 请 与 作者 联系 ， 我 们 将 全 力 提供 帮助 。 
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在 学 习 PHP 之 前 ， 读 者 需要 了 解 PHP 的 基本 概念 、PHP 的 特点 、 
用 工具 等 知识 。 本 章 将 主要 讲述 PHP 的 入 门 知识 
PHP 先 有 一 个 初步 的 了 解 。 


PHP 开发 常 
。 通 过 本 章 的 学 习 ， 读 者 将 对 
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PHP+MySQL 动 态 网 站 开发 
案例 课堂 ~ 


1.1 认识 PHP 
PHP 语言 与 其 他 语言 有 什么 不 同 ? 读者 首先 需要 理解 PHP 的 概念 和 发 展 历程 。 
1 忻 么 是 有 PP 


PHP 全 名 为 Personal Home Page， 是 英文 Hypertext Preprocessor( 超 级 文本 预 处 理 语言 ) 的 
别名 。PHP 作为 在 服务 器 端 执行 的 柑 入 HTML 文档 的 脚本 语言 ， 其 风格 类 似 于 C 语言 ， 被 运 
用 于 动态 网 站 制作 。PHP 借鉴 了 C 和 Java 等 语言 的 部 分 语法 ， 并 有 自己 独特 的 特性 ， 使 Web 
开发 者 能 够 快速 地 编写 动态 地 生成 页 面 的 脚本 。 

对 于 初学 者 而 言 ，PHP 的 优势 是 可 以 快速 入 门 。 与 其 他 编程 语言 相 比 ，PHP 是 将 程序 幅 
入 到 HTML 文档 中 去 执行 的 ， 执 行 效率 比 完 全 生成 HIML 标记 的 方式 要 高 许多 。PHP 还 可 以 
执行 编译 后 的 代码 ， 编 译 可 以 起 到 加 密 和 优化 代码 运行 的 作用 ， 使 代码 运行 得 更 快 。 另 外 ， 
PHP 具有 非常 强大 的 功能 ， 能 实现 所 有 的 CGI 功能 ， 而 且 支 持 几乎 所 有 流行 的 数据 库 和 操作 
系统 。 最 重要 的 是 ，PHP 还 可 以 用 C、C++ 进 行程 序 扩展 。 


1.1.2 PHP 的 发 展 过 程 


在 当今 诸多 Web 开发 语言 中 ，PHP 是 比较 出 众 的 一 种 。 与 其 他 脚本 语言 不 同 ，PHP 是 经 
过 全 世界 免费 代码 开发 者 共同 努力 ， 才 发 展 到 今天 的 规模 的 。 要 想 了 解 PHP， 首 先 应 该 从 它 
的 发 展 历程 谈 起 。 

1994 年 ，Rasmus Lerdorf 首次 开发 了 PHP 程序 设计 语言 。1995 年 6 月 ，Rasmnus Lerdorf 
在 Usenet 新 闻 组 comp.infosystems.www.authoring.cgi 上 发 布 了 PHP 1.0 声明 。 这 个 早期 版 本 
提供 了 访客 留言 本 、 访 客 计数 器 等 简单 的 功能 。 

1995 年 ， 第 2 版 的 PHP 问 市 ， 定 名 为 PHP/FI(Form Interpreter)。 在 这 一 版 本 中 ， 加 入 了 
可 以 处 理 更 复杂 的 嵌入 式 标签 语言 的 解析 程序 ， 同 时 加 入 了 对 数据 库 MySQL 的 支持 。 自 
此 ， 葛 定 了 PHP 在 动态 网 页 开发 上 的 影响 力 。 自 从 PHP 加 入 了 这 些 强大 的 功能 以 后 ， 它 的 使 
用 量 猛 增 。 据 初步 统计 ， 在 1996 年 底 ， 有 15000 个 Web 网 站 使 用 了 PHP/FI; 而 在 1997 年 中 
期 ， 这 一 数字 超过 了 50000。 

PHP 前 两 个 版 本 的 成 功 ， 让 其 设计 者 和 使 用 者 对 PHP 的 未 来 充满 了 信心 。1997 年 ， 
Zeev Suraski 及 Andi GutmansPHP 加 入 了 开发 小 组 ， 他 们 自愿 重新 编写 了 底层 的 解析 引擎 ， 又 
有 其 他 很 多 人 也 自愿 加 入 了 PHP 的 工作 ， 使 得 PHP 成 为 真正 意义 上 的 开源 项 目 。 

1998 年 6 月 ， 发 布 了 PHP 3.0 声明 。 在 这 一 版 本 中 ，PHP 可 以 跟 Apache 服务 器 紧密 地 结 
合 ， 再 加 上 它 不 断 地 更 新 及 加 入 新 的 功能 ， 且 支持 几乎 所 有 主流 和 非 主流 数据 库 ， 拥 有 非常 
高 的 执行 效率 ， 这 些 优势 使 1999 年 使 用 PHP 的 网 站 超过 了 150000。 

PHP 经 过 3 个 版 本 的 演化 ， 已 经 变 成 一 种 非常 强大 的 Web 开发 语言 。 这 种 语言 非常 容易 
使 用 ， 而 且 它 拥有 一 个 强大 的 类 库 ， 类 库 的 命名 规则 也 十 分 规范 ， 新 手 就 算 对 一 些 函 数 的 功 
能 不 了 解 ， 也 可 以 通过 函数 名 猜测 出 来 。 这 使 得 PHP 十 分 容易 学 习 ， 而 且 PHP 程序 可 以 直接 


使 用 HTML 编辑 器 来 处 理 ， 因 此 ，PHP 变 得 非常 流行 ， 有 很 多 大 的 门户 网 站 都 使 用 了 PHP 作 
为 自己 的 Web 开发 语言 ， 例 如 新 浪 网 等 。 

2000 年 5 月 ， 推 出 了 划时代 的 版 本 PHP 4。 使 用 了 一 种 “编译 -执行 ”模式 ， 核 心 引擎 更 
加 优越 ， 提 供 了 更 高 的 性 能 ， 而 且 还 包含 了 其 他 一 些 关 键 功能 ， 比 如 支持 更 多 的 Web 服务 
器 、HTTP Sessions 支持 、 输 出 缓存 、 更 安全 的 处 理 用 户 输入 的 方法 和 一 些 新 的 语言 结构 。 

PHP 目前 的 最 新 版 本 是 PHP 5， 在 PHP 4 基础 上 做 了 进一步 的 改进 ， 功 能 更 加 强大 ， 执 
行 效率 更 高 。 本 书 将 针对 PHP 5 版 本 ， 讲 解 PHP 的 实用 技能 。 


1.1.3 PHP 语言 的 优势 


PHP 能 够 迅速 发 展 ， 并 得 到 广大 使 用 者 的 喜爱 ， 主 要 原因 是 PHP 不 仅 有 一 般 脚本 都 具备 
的 功能 ， 而 且 有 它 自 身 的 优势 ， 具 体 特点 如 下 。 

e 源 代码 完全 开放 : 所 有 的 PHP 源 代 码 事实 上 都 可 以 得 到 。 读 者 可 以 通过 Intemet 获 
得 所 需要 的 源 代 码 ， 快 速 修改 和 利用 。 

@ 完全 免费 : 与 其 他 技术 相 比 ，PHP 本 身 是 免费 的 。 使 用 PHP 进行 Web 开发 无 须 支 
付 任何 费用 。 

@ ”语法 结构 简单 :PHP 结合 了 C 语言 和 Perl 语言 的 特色 ， 编 写 简单 ， 方 便 易 懂 。 可 以 
嵌入 HTML 语言 中 ， 相 对 于 其 他 语言 编辑 简单 ， 实 用 性 强 ， 更 适合 初学 者 学 习 。 

e@ 跨 平 台 性 强 : PHP 是 服务 器 端 脚本 ， 可 以 运行 于 Unix、Linux、Windows 环境 下 。 

e@ ”效率 高 : PHP 消耗 非常 少 的 系统 资源 ， 并 且 程序 开发 快 ， 运 行 速度 快 。 

e ”强大 的 数据 库 支持 :PHP 支持 目前 所 有 的 主流 和 非 主流 数据 库 ， 使 PHP 的 应 用 对 象 
非常 广泛 。 

e@ 面向 对 象 : 在 PHP 5.5 中 ， 面 向 对 象 方面 有 了 很 大 的 改进 ， 现 在 PHP 完全 可 以 用 来 
开发 大 型 商业 程序 了 。 


1.2 PHP 能 干什么 


初学 者 也 许 会 有 疑问 ，PHP 到 底 能 做 什么 呢 ? 下 面 就 来 介绍 PHP 的 应 用 领域 。 

1. 作为 服务 端 脚本 

PHP 最 主要 的 应 用 领域 是 作为 服务 器 端 脚本 。 服 务 器 脚本 的 运行 需要 具备 3 项 配置 : 
PHP 解析 器 、Web 浏览 器 和 Web 服务 器 。 在 Web 服务 器 上 安装 并 配置 PHP， 然 后 用 Web 浏 


览 器 访问 PHP 程序 ， 获 得 输出 。 在 学 习 的 过 程 中 ， 读 者 只 要 在 本 机 上 配置 Web 服务 器 ， 即 可 
浏览 制作 的 PHP 页 面 。 


2. 作为 命令 行 脚本 


命令 行 脚本 与 服务 端 脚本 不 同 ， 编 写 的 命令 行 脚本 并 不 需要 任何 服务 器 或 浏览 器 ， 在 命 
令 行 脚本 模式 下 ， 只 需要 PHP 解析 器 执行 即 可 。 这 些 脚本 被 用 在 Windows 和 Linux 平台 下 作 
为 日 常 运行 脚本 ， 也 可 以 用 来 处 理 简单 的 文本 。 


sl 


所 莱 dHd_ 世 上 泪 


GG 


辐 。 PHP+MysQL 动 态 网 站 开发 
案例 课 党 四 ~- 


3. 用 来 编写 桌面 应 用 程序 


PHP 在 桌面 应 用 程序 的 开发 中 并 不 常用 ， 但 是 如 果 用 户 希 望 在 客户 端 应 用 程序 中 使 用 
PHP 编写 图 形 界面 应 用 程序 ， 可 以 通过 PHP-GTK 来 编写 这 些 程序 。PHP-GTK 是 PHP 的 扩 
展 ， 并 不 包含 在 标准 的 开发 包 中 ， 开 发 用 户 需要 单独 编译 它 。 


1.3 ”常用 的 开发 工具 


NN 可 以 编写 PHP 代码 的 工具 很 多 ， 常 见 的 有 Dreamweaver、PHPEdit、PHPed 和 FrontPage 
SS 等 ， 甚 至 用 Word 和 记事 本 等 常用 工具 也 可 以 书写 PHP 源 代码 。 
1.3.1 PHP 代码 开发 工具 


常见 的 PHP 代码 开发 工具 如 下 。 
1.PHPEdit 


PHPEdit 是 一 款 Windows 下 优秀 的 PHP 脚本 IDE( 集 成 开发 环境 )。 该 软件 为 快速 、 便 捷 
地 开发 PHP 脚本 提供 了 多 种 工具 ， 功 能 包括 : 语法 关键 词 高 亮 ， 代 码 提示 、 浏 览 ， 集 成 PHP 
调试 工具 ; 帮助 生成 器 ， 自 定义 快捷 方式 ，150 多 个 脚本 命令 ;键盘 模板 ;报告 生成 器 ;快速 
标记 和 插件 等 。 


2. gPHPedit 


gPHPedit 是 在 Linux 下 十 分 流行 的 免费 的 PHP 编辑 器 。 它 小 巧 而 功能 强大 。 它 是 以 
Linux 下 的 gedit 文本 编辑 器 为 基础 ， 专 门 设计 ， 用 于 编辑 PHP 和 HTML 的 编辑 器 ， 可 以 突 
出 显示 PHP、HTML、CSS 和 SQL 语句 。 在 编写 代码 的 过 程 中 能 够 提供 函数 列表 参考 、 函 数 
参数 参考 ， 可 以 搜索 和 检测 编程 语法 等 。 总 之 ， 这 是 一 款 完 全 免费 的 优秀 PHP 编辑 器 。 


3. phpDesigner 


phpDesigner 是 一 款 功 能 强大 的 、 运 行 高 效 的 、 优 秀 的 PHP 编辑 平台 。 它 是 结合 PHP、 
XHTML、JavaScript、CSS 等 技术 的 综合 Web 应 用 开发 平台 。 它 能 够 自动 捕获 代码 文件 中 的 
class、function、variables 等 编程 元 素 ， 并 加 以 整理 ， 在 编程 过 程 中 给 予 提示 。 除 此 以 外 ， 它 
还 兼容 了 各 种 流行 的 类 库 和 框架 ， 可 以 协同 工作 ， 比 如 JavaScript 的 jQuery 库 、YUI 库 、 
prototype 库 等 ， 此 外 还 有 PHP 流行 的 zend 框架 、symfony 框架 、cakephp 框架 、yii 框架 等 。 
另外 ， 它 还 拥有 xdebug 工具 、svn 版 本 管理 等 工具 。 可 以 说 ，phpDesigner 是 独立 于 Eclipse 
之 外 的 ， 集 PHP 开发 需求 之 大 成 的 又 一 款 优秀 的 平台 。 


4. Zend Studio 


Zend Studio 是 由 Zend 科技 开发 的 一 个 针对 PHP 的 全 面 的 开发 平台 。 这 个 IDE 融合 了 
Zend Server 和 Zend 框架 ， 并 且 融 合 了 Eclipse 开发 环境 。 Eclipse 是 最 早 用 于 Java 的 IDE 环 
境 ， 但 是 由 于 其 优良 的 特性 和 对 PHP 的 支持 ， 已 经 成 为 很 有 影响 力 的 PHP 开发 工具 。 现 在 最 


新 的 Eclipse PHP 开发 环境 为 Eclipse PDT 2.2.0 版 本 。 它 拥有 支持 Windows、Linux 和 Mac 系 
统 的 软件 包 ， 可 以 说 是 十 分 全 面 的 ， 拥 有 比较 完备 的 体系 ， 但 它 是 一 个 收费 的 工具 。 


1.3.2 网 页 设计 工具 
下 面 介绍 几 种 常见 的 网 页 设计 工具 。 


1. Dreamweaver 


Dreamweaver 是 网 页 制作 三 剑客 之 一 ， 其 功能 更 多 地 是 体现 在 对 Web 页 面 的 HTML 设计 
上 。 随 着 Web 语言 的 发 展 ，Dreamweaver 早已 不 再 局 限于 网 页 设计 方面 ， 它 更 多 地 着 重 支 持 
各 种 流行 的 Web 前 后 台 技 术 的 综合 运用 。Dreamweaver 对 PHP 的 支持 十 分 到 位 。 不 但 对 PHP 
的 不 同方 面 能 够 清晰 地 进行 表示 ， 并 且 能 够 给 出 足够 的 编程 提示 ， 使 编程 过 程 相当 流畅 。 


2. FrontPage 
FrontPage 是 微软 公司 出 品 的 一 款 网 页 制作 入 门 级 软件 。FrontPage 使 用 简单 方便 ， 会 用 
Word 就 能 做 网 页 ， 所 见 即 所 得 是 其 特点 ， 该 软件 结合 了 设计 、 拆 分 、 代 码 和 预览 4 种 模式 。 


1.3.3 文本 编辑 工具 


常见 的 文本 编辑 工具 很 多 ， 如 UltraEdit 和 记事 本 等 。 

1. UltraEdit 

UltraEdit 是 一 款 功 能 强大 的 文本 编辑 器 ， 可 以 编辑 文本 、 十 六 进 制 码 、ASCII 码 ， 完 全 
可 以 取代 记事 本 (如 果 电 脑 配 置 足够 强大 )。UltraEdit 内 建英 文 单字 检查 、C++ 及 VB 指令 突 
显 ， 可 同时 编辑 多 个 文件 ， 而 且 即 使 开启 很 大 的 文件 ， 速 度 也 不 会 慢 。 软 件 附 有 HTML 标签 
颜色 显示 、 搜 寻 蔡 换 以 及 无 限制 的 还 原 功 能 ， 一 般 用 来 修改 EXE 或 DLL 文件 ， 是 能 够 满足 
我 们 一 切 编辑 需要 的 编辑 器 。 

2. 记事 本 


记事 本 是 Windows 系统 自 带 的 文本 编辑 工具 。 具 备 最 基本 的 文本 编辑 功能 ， 体 积 小 巧 、 
启动 快 、 占 用 内 存 低 、 容 易 使 用 。 记 事 本 的 主 窗口 如 图 1-1 所 示 。 


(RE(E) 磺 区 (Oj 二 者 M) 者 向 (H) 


1-1 记事 本 的 主 窗口 


谋 兽 dHd_ 世上 中 鲁 
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在 使 用 记事 本 程序 编辑 PHP 文档 的 过 程 中 ， 需 要 注意 保存 方法 和 技巧 。 在 “另存 为 ”对 
话 框 中 输入 文件 名 称 ， 后 缀 名 为 php， 另 外 ， 


“保存 类 型 ”设置 为 “所 有 文件 ” 即 可 ， 如 图 1-2 


所 示 。 
GO «ware» we phpss » co 加 EZ 加 
给 织 ”新 建文 件 夫 站 局 
Bw | 修改 日 其 让 
国 凤 + 
Eb 
半生 T 切 
2 | 
网 应 | 
本 计算 人 
CA] 
局 本 地 三 盘 (D:;) 
文人 名 (M: myphp.php ~ 
保存 闫 型 (): [所 有 文件 (省 相 
aan SR Ant a 
图 1-2 “另存 为 ”对 话 框 
1.4 疑难 解 惑 


疑问 1: 如 何 快速 了 解 PHP 的 应 用 技术 ? 


在 学 习 的 过 程 中 ， 用 户 可 以 随时 查阅 PHP 的 相关 资料 。 启 动 正 浏览 器 ， 在 地 址 栏 中 输 
入 “http://www.baidu.com”， 打 开 搜 索引 擎 ， 输 入 需要 搜索 的 内 容 ， 即 可 了 解 相 关 的 技术 。 


疑问 2: 如 何 选 择 PHP 开发 软件 ? 


不 管 是 哪个 开发 工具 ， 在 PHP 开发 过 程 中 ， 都 要 有 对 PHP 的 语法 和 数据 进行 分 色 表示 的 
能 力 ， 以 方便 开发 者 编写 程序 。 进 一 步 的 功能 是 对 代码 编写 要 拥有 提示 的 能 力 ， 即 对 PHP 的 
数据 类 型 、 运 算 符 、 标 识 、 名 称 等 都 能 给 出 提示 。 

在 诸多 开发 工具 中 ， 我 们 选择 比较 适合 自己 的 即 可 。 就 初学 者 而 言 ， 使 用 phpDesigner 比 
较 好 ， 它 支持 PHP、XHTML、JavaScript、CSS 等 Web 开发 的 常用 技术 。 


在 编写 PHP 文件 之 前 ， 读 者 需要 配置 PHP 服务 器 ， 包 括 
o 何 获得 PHP 安装 资源 包 等 ， 本 章 详细 讲解 目前 常见 的 主流 PHP 服务 器 配置 


案 : PHP 5+IIS 和 PHP 5+Apache。 另 
合 包 。 最 后 通过 一 个 实战 演练 ， 使 读者 可 以 检查 Web 服务 器 
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2.1 PHP 服务 器 概述 


在 学 习 PHP 服务 器 之 前 ， 读 者 需要 了 解 HTML 网 页 的 运行 原理 。 网 页 浏览 者 在 客户 端 通 
过 浏览 器 向 服务 器 发 出 页 面 请 求 ， 服 务 器 接收 到 请 求 后 ， 将 页 面 返回 到 客户 端的 浏览 器 ， 这 
样 网 页 浏览 者 即 可 看 到 页 面 显示 效果 。 


PHP 网 站 ， 需 要 搭建 PHP 服务 器 。 
PHP 网 站 的 运行 原理 如 图 2-1 所 示 。 


PIP 网 站 的 服务 


数据 库 
图 2-1 PHP 网 站 的 运行 原理 


从 图 2-1 可 以 看 出 ，PHP 程序 运行 的 基本 流程 如 下 。 

(1) 网 页 浏览 者 首先 在 浏览 器 的 地 址 栏 中 输入 要 访问 的 主页 地 址 ， 并 按 Enter 键 来 触 
发 这 个 请 求 。 

(2) 浏览 器 将 请 求 发 送 到 PHP 网 站 服务 器 。 网 站 服务 器 根据 请 求 读 取 数据 库 中 的 数据 。 

(3) 通过 Web 服务 器 向 客户 端 发 送 处 理 结果 ， 客 户 端 的 浏览 器 显示 最 终 页 面 。 


2 由 于 在 客户 端 显示 的 只 是 服务 器 端 处 理 过 的 HTML 代码 页 面 ， 所 以 网 页 浏览 者 
装 看 不 到 PHP 代码 ， 这 样 可 以 提高 代码 的 安全 性 。 同 时 在 客户 端 不 需要 配置 PHP 环 
境 ， 只 要 安装 了 浏览 器 即 可 。 


2.2 安装 PHP 前 的 准备 工作 
在 安装 PHP 之 前 ， 读 者 应 当 了 解 所 需要 的 软 硬 件 环境 和 如 何 获取 PHP 安装 资源 包 。 
2.2.1 软 硬 件 环 境 


大 部 分 软件 在 安装 的 过 程 中 都 需要 软 硬 件 环境 的 支持 ， 当 然 PHP 也 不 例外 。 在 硬件 方 
面 ， 如 果 只 是 为 了 学 习 上 的 需求 ，PHP 只 需要 一 台 普 通 的 电脑 即 可 。 在 软件 方面 ， 需 要 根据 
实际 工作 的 需求 ， 选 择 不 同 的 Web 服务 软件 。 

PHP 具有 跨 平 台 特 性 ， 所 以 PHP 开发 用 什么 样 的 系统 不 太 重要 ， 开 发 出 来 的 程序 能 够 很 
轻松 地 移植 到 其 他 操作 系统 中 。 


| 


另外 ，PHP 开发 平台 支持 目前 主流 的 操作 系统 ， 包 括 Windows 系列 、Linux、Unix 和 
Mac OSX 等 。 

本 书 以 Windows 平台 为 例 进行 讲解 。 

此 外 ， 用 户 还 需要 安装 Web 服务 软件 。 目 前 ，PHP 支持 大 多 数 Web 服务 软件 ， 常 见 的 
有 IIS、Apache、PWS 和 Netscape 等 。 比 较 流 行 的 是 IS 和 Apache， 下 面 将 详细 讲述 这 两 种 
Web 服务 器 的 安装 和 配置 方法 。 


2.2.2 获取 PHP 安装 资源 包 


PHP 安装 资源 包 中 包括 了 安装 和 配置 PHP 服务 器 所 需 的 文件 和 PHP 扩展 函数 库 。 获 取 
PHP 安装 资源 包 的 方法 比较 多 ， 很 多 网 站 都 提供 PHP 安装 包 ， 但 是 建议 读者 从 官方 网 站 下 
载 ， 具 体操 作 步 骤 如 下 。 

EC 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 下 载 地 址 “http:windows.php.net/download”， 

按 Enter 键 确认 ， 登 录 到 PHP 下 载 网 站 ， 如 图 2-2 所 示 。 


项 刚强 天 远 咒 副 “ 几 Z 小 


GG 


| hp//windows. P ~ cx| 车 php For Windows: Bineri.. > 
文件 ( 朋 ” 妨 久 (E) ”查看 (V) ” 收 基 交 A】 工具 (帮助 (H) 


Download: OA Releass 


PHP For Windows 
This stte ls dedicated to Binaries and sources Releases 
supporting PHP on Microsoft Salect mn option to dect mecess.. [w] 
Windows. It also supports 

ports of PHP extenstons or 

features as well as 


Pproviding special builds for PHP 5.6 
the various Windows = 
architectures, i Ek 


1f you like to build your own 
PHP binaries, instructions 


can be found on the Wik. PHP 5.5 (5.5.11) 


2-2 ”PHP 下 载 页 面 


进入 下 载 页 面 后 ， 单 击 Binaries and sources Releases 下 方 的 下 拉 按 钮 ， 在 弹出 
的 下 拉 列 表 中 选择 适合 的 版 本 ， 这 里 选择 PHP 5.5 版 本 ， 如 图 2-3 所 示 。 


5 下 拉 列 表 中 的 VC11 代表 the Visual Studio 2012 compiler 编译 器 编译 ， 通 常用 在 
SIHS+PHP 服 务 器 下 。 要 求 用 户 安装 Visual C++ Redistributable for Visual Studio 2012。 


ED 将 显示 所 选 版 本 号 中 PHP 安装 包 的 各 种 格式 ， 这 里 选择 Zip 压缩 格式 ， 单 击 
Zip 链接 ， 如 图 2-4 所 示 。 
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【< @ mapywindows P= B OX | pHp Forwndows Binari.. x 
Er CE ATE OUETT 


PHP For Windows 
This site is dedicated to 
supporting PHP on Microsoft 
‘Windows. It also Supports 
ports of PHP extensions or 
features as well as 
providing special buids for 
the various Windows 
architectures. 


FF you ke to build your own 
PHP binaries, instructions 
‘an be found on the Wilg, 


V9 >36 Thraad Safe 
PHP 5.5 (5.5.11 


Download spurce cods [22.32MB] 
PECL For Windows 


PEC! emtoncinne fne 
[ 


VC11 x86 Non Thread Safe (2014-Apr-09 01:52:18) - 


2-3 ”选择 需要 的 版 本 


入 ntpy/windows. 只- B 0 X | @ PHP For Windows: Binari.. 
文件 (站 ” 妨 锅 (E) 。 坦 看 (V) 收 基 闪 (A) 工具 (T) 帮助 (H) 
VC11 x86 Non Thread Safe (2014-Apr-09 01:52:18) 


和 18.35MB] 
: a2c4f5a18bca3db0alf6376273537d496b5734fd 


日 Debua Pack [9.11MB] 
shal: 19d337d56a06adcbdf192bd80eb7a0f8cebb4b99 


VC11 x86 Thread Safe (2014-Apr-09 01:52:19) 


s Zp [18.42MB] 
shal: 057f5d3ff5ed9c342c9bd3f7c836bd4e44e3d75b 


® Debug Pack [9.29MB] 
shal; 28d3a0c91a251de3647ac8da82c90169d7af4c47 


VC11 x64 Non Thread Safe (2014-Apr-09 22:29:01) 
Note: x64 builds are currently experimental 


1 [ mT 


http://windows.php.net/downloads/releases/php-5.5.11-nts-Win32-VC11-x86.zip 


图 2-4 ”选择 需要 的 版 本 格式 
EEC 弹出 “另存 为 ”对 话 框 ， 选 择 保存 路 径 ， 然 后 保存 文件 即 可 ， 如 图 2-5 所 示 。 
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2-5 “另存 为 ”对 话 框 


2.3 PHP + lIS 服务 器 安装 配置 
下 面 介绍 PHP + IIS 服务 器 架构 的 配置 方法 和 技巧。 


2.3.1 IIS 简介 及 其 安装 


IIS 是 Intemet Information Services( 互 联网 信息 服务 ) 的 简称 ， 它 是 由 微软 公司 提供 的 基于 
Windows 的 互联 网 基本 服务 。 由 于 它 功能 强大 ， 操 作 简单 和 使 用 方便 ， 所 以 是 目前 较为 流行 
的 Web 服务 器 之 一 。 

目前 IS 只 能 运行 在 Windows 系列 的 操作 系统 上 ， 针 对 不 同 的 操作 系统 ，IIS 也 有 不 同 的 
版 本 。 下 面 以 Windows 7 为 例 进 行 讲解 ， 默 认 情况 下 ， 此 操作 系统 没有 安装 IIS 。 

安装 IS 组 件 的 具体 步骤 如 下 。 

单 击 “ 开 始 ” 按 钮 ， 在 弹出 的 “开始 ”菜单 中 选择 “控制 面板 ”菜单 命令 ， 如 

图 2-6 所 示 。 
ERP 弹出 “控制 面板 ”窗口 ， 双 击 “ 程 序 ” 选 项 ， 如 图 2-7 所 示 。 


GG 


图 2-6 选择 “控制 面板 ”菜单 命令 图 2-7 “控制 面板 ”窗口 
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EEOUe 弹出 “程序 ”窗口 ， 选 择 “打开 或 关闭 Windows 功能 ”选项 ， 如 图 2-8 所 示 。 
EDU 在 弹出 的 “Windows 功能 ”窗口 中 ， 选 中 “Intermet 信息 服务 ” 复 选 框 ， 单 击 
“确定 ”按钮 ， 如 图 2-9 所 示 。 


OE BE==3 
me 
i 和 
本 
国有 Tablet PC 组 件 
回 卡 Telnet 服务 器 
回电 Telnet 吉 疡 污 
四 县 TFTP 可 户 毅 
加 上 Windows Process Activation Service 
| 图 2-8 “程序 ”窗口 图 2-9 “Windows 功能 ”窗口 
BS EEDRD 安装 完成 后 ， 即 可 测试 是 否 已 经 安装 成 功 。 在 正 浏览 器 的 地 址 栏 中 输入 
\ “http://localhost/”， 安 装 成 功 后 会 弹出 IIS 的 欢迎 页 面 ， 如 图 2-10 所 示 。 


个 htpy/localhost 只 ~ Scx] 


internet information services 


Te 


2-10 “lS 的 欢迎 页 面 
2.3.2 安装 PHP 
IIS 安装 完成 后 ， 即 可 开始 安装 PHP。PHP 的 安装 过 程 大 致 分 成 3 个 步骤 。 


领唱 
第 辕 
IN 
1. 解压 和 设置 安装 路 径 朝 
将 2.2.2 小 节 中 获取 到 的 安装 资源 包 解压 缩 ， 解 压缩 后 得 到 的 文件 夹 中 存放 着 PHP 所 需 EE 
要 的 文件 。 将 该 文件 夹 复制 到 PHP 的 安装 目录 中 。PHP 的 安装 路 径 可 以 根据 需要 进行 设置 ， 曙 
例如 本 书 设置 为 D:\PHP5\， 文 件 夹 复 制 后 的 效果 如 图 2-11 所 示 。 EM 
环 
境 
GO Hn , +ema 0 , Pres» EEE P| 
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cn 本 地 澡 页 (Fi 
] 34 个 对 象 
图 2-11 PHP 的 安装 目录 
2. 配置 PHP 


在 安装 目录 中 ， 找 到 php.ini-development 的 文件 ， 此 文件 正 是 PHP 5.4 的 配置 文件 。 将 这 
个 文件 的 扩展 名 .ini-development 修改 为 .ini， 然 后 用 记事 本 打开 。 文 件 中 参数 很 多 ， 所 以 建议 
读者 使 用 记事 本 的 查找 功能 ， 快 速 查 找 需要 的 参数 。 

查找 并 修改 相应 的 参数 值 extension_dir=“D:\PHP5\ext"， 此 参数 为 PHP 扩展 函数 的 查找 路 
径 ， 其 中 “D:\PHP5\” 为 PHP 的 安装 路 径 ， 读 者 可 以 根据 自己 的 安装 路 径 进行 修改 。 采 用 同 
样 的 方法 ， 修 改 参 数 cgi.force_redirect=0。 

另外 ， 去 除 下 面 的 参数 值 扩展 前 的 引号 : 


extension=php_curl.d1ll 
extension=php gd2.d11 
extension=php mbstring.dll 
extension=php mysql.dll 
extension=php pdo mysql.d1l 
extension=php_ pdo _ odbc.d1ll 
extension=php xmlrpc.d1ll 
extension=php xsl.dll 
extension=php_ zip.d1ll 


具体 如 图 2-12 所 示 。 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 四 一 


本 'c -记事 
文件 (有 锋 饮 (E) 禄 式 (O) 查看 V) 帮助 (H) 

extension=php_bz2. dll 

extension=php_curl. dll 

extension=php_fileinfo. dll 

extension=php_gd2. dll 

extension=php_gettext. dll 

ertension=php_gmp. dll 

extension=php_intl. dll 

extension=php_imap. dll 

extension=php_interbase. dll 

extension=php_ldap. dll 

extension=php_mbstring. dll 

extension=php_exif, dll ; Must be after mbstring as it depends on it 
extension=php_mysql. dll 

extension=php_mysqli. dll 

extension=php_oci8. dll ; Use with Oracle 10gR2 Instant Client 
extension=php_oci8_11g. dll ; Use with Oracle 11gR2 Instant Client 
extension=php_openssl. dll 

extension=php_pdo_firebird. dll 

extension=php_pdo_mysql. dll 

extension=php_pdo_oci. dll 

extension=php_pdo_odbc. dll 

extension=php_pdo_pgsal. dll 


图 2-12 去 除 引 号 
3. 添加 系统 变量 


要 想 让 系统 运行 PHP 时 找到 上 面 的 安装 路 径 ， 就 需要 将 PHP 的 安装 目录 添加 到 系统 变量 
中 。 具 体操 作 步骤 如 下 。 
右 击 桌面 上 的 “计算 机 ”图 标 ， 在 弹出 的 快捷 菜单 中 选择 “属性 ”菜单 命令 ， 
打开 “系统 ”窗口 ， 如 图 2-13 所 示 。 
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[有 Windows 版 = 
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捕 积 所 有 日 2009 Microsoft Corporation， 保 祷 所 有 权利 


网 于 大 
| 


系统 
i vindows7 认 及 安 半 析 
Sm 要 好 不 可 用 
处 理 占 : AMD Athlonftm) I1 X2 245 Processor 2.90 GHz 
安装 内 存 (RAM): 400 GB (3.25 6B 可 用 ) 
Bm: 32 位 和 作 拖 
与 再 参 赐 和 讼 有 可 用 于 此 至 示 吉 的 笔 到 对 符 绽 入 
i 新 鞠 卜 家 加 windows7 旗 通 安 装 丘 7.0 支持 
Windows Update 
性 信和 和 IT 内 的 We 


2-13 “系统 ”窗口 


EU) 单 击 “ 高 级 系统 设置 ”按钮 ， 弹 出 “系统 属性 ”对 话 框 ， 如 图 2-14 所 示 。 
国 了 E> 单 击 “ 环 境 变量 ”按钮 ， 弹 出 “环境 变量 ”对 话 框 。 在 环境 变量 列表 中 选择 变 
量 “Path”， 单 击 “编辑 ”按钮 ， 如 图 2-15 所 示 。 


全 
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计算 机 名 [硬件 “| 高 级 ”| 系统 保护 | 运程 


要 进行 大 多 教 更 改 ， 您 必须 作为 管理 员 登 录 。 


性 能 
视觉 效果 ， 处 理 器 计划 ， 内 存 使 用 ， 以 及 虚拟 内 存 


用 户 配置 文件 
与 您 登录 有 关 的 点 面 设置 


Administrator 的 用 , 


户 朗 量 o) 


值 
WUSERPROFILE%\AppData\Local\Temp 
KUSERPROFILEX\AppData\Local\Temp 
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Er 


2-14 “系统 属性 ”对 话 框 


如 图 2-16 所 示 。 


ER 单 击 “ 确 定 ” 按 钮 ， 返 回 到 “环境 变量 ”对 话 框 ， 如 图 2-17 所 示 。 依 次 单 击 
“确定 ”按钮 ， 即 可 关闭 窗口 ， 然 后 重新 启动 计算 机 ， 使 设置 的 环境 变量 生效 。 


变量 名 0 : Path 


变量 值 ): vologies\ATI. ACE\Core-Static; d: \PHP 


[| 


2-16 “编辑 系统 变量 ”对 话 框 


2.3.3 设置 虚拟 目录 


AR Pamilw 1R Moadel R Stenninz 


新 建 o) ] 


图 2-15 “环境 变量 ”对 话 框 
EUZ 弹出 “编辑 系统 变量 ”对 话 框 ， 在 “变量 值 ”文本 框 的 末尾 输入 “;d:\PHP5”， 
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haninistrater 的 用 户 朗 量 0) 


值 
WUSERPROPTLEX\AppDat a\Local\Tenp 
WUSERPROFTLEX\AppDat a\Local \Tenp 
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“环境 变量 ”对 话 框 


如 果 用 户 是 按照 前 述 的 方式 来 启动 IS 网 站 服务 器 ， 目 前 整个 网 站 服务 器 的 根 目录 就 位 于 
< 系统 盘 符 :netpubvwwwroot> 中 ， 也 就 是 如 果 要 添加 网 页 到 网 站 中 显示 ， 都 必须 放置 在 这 个 
目录 之 下 。 但 是 会 发 现 这 个 路 径 不 仅 太 长 ， 也 不 好 记 ， 使 用 起 来 相当 不 方便 。 
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这 些 问 题 都 可 以 通过 修改 虚拟 目录 来 解决 ， 具 体操 作 步 又 如 下 。 
ED 在 桌面 上 右 击 “ 我 的 电脑 ”图 标 ， 在 弹出 的 快捷 方式 中 选择 “管理 ”菜单 命 
令 ， 弹 出 “计算 机 管理 ”窗口 ， 在 左 侧 的 列表 中 展开 “服务 和 应 用 程序 ”选项 ， 选 


择 “Internet 信息 服务 (IIS) 管 理 器 ”选项 ， 在 右 侧 选择 “Default Web Site” 选 项 后 ， 
右 击 ， 在 弹出 的 快捷 菜单 中 选择 “添加 虚拟 目录 ”命令 ， 如 图 2-18 所 示 。 
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图 2-18 “计算 机 管理 ”窗口 
EEIRPD 弹出 “添加 虚拟 目录 ”对 话 框 ， 在 “别名 ”文本 框 中 输入 虚拟 网 站 的 名 称 ， 这 


里 输入 “php5.5”， 然 后 选择 物理 路 径 为 “D:\php”， 单 击 “ 确 定 ” 按 钮 ， 如 图 2-19 
所 示 。 


网 站 名 称 : Default Web Site 
路 径 : , 


别名 (A): 


图 2-19 “添加 虚拟 目录 ”对 话 框 


这 样 就 完成 了 IIS 网 站 服务 器 设置 的 更 改 ， 此 时 IIS 网 站 服务 器 的 网 站 虚拟 目录 已 经 更 改 
为 <D:\php> 了 。 


2.4 PHP + Apache 服务 器 的 环境 搭建 


Apache 支持 大 部 分 操作 系统 ， 搭 配 PHP 程序 的 应 用 ， 就 可 以 开发 出 功能 强大 的 交互 网 
站 。 本 节 主 要 讲述 PHP 5 + Apache 服务 器 的 搭建 方法 。 


2.4.1 Apache 简介 


Apache 是 世界 上 使 用 量 排名 第 一 的 Web 服务 器 软件 。 它 具有 跨 平台 性 和 安全 性 ， 可 以 运 
行 在 几乎 所 有 广泛 使 用 的 计算 机 平台 上 ， 是 最 流行 的 Web 服务 器 端 软件 之 一 。 

与 一 般 的 Web 服务 器 相 比 ，Apache 的 主要 特点 如 下 。 

e@ ” 跨 平 台 应 用 : 几乎 可 以 在 所 有 的 计算 机 平台 上 运行 。 

@ ”开放 源 代码 : Apache 服务 程序 由 全 世界 的 众多 开发 者 共同 维护 ， 并 且 任何 人 都 可 以 
自由 使 用 ， 充 分 体现 了 开源 软件 的 精神 。 

e@ 支持 HITP 1.1 协议 ; Apache 是 最 先 使 用 HITP 1.1 协议 的 Web 服务 器 之 一 ， 它 完 
兼容 HTTP 1.1 协议 并 与 HITP 1.0 协议 向 后 兼容 。Apache 已 为 新 协议 所 提供 的 全 部 
内 容 做 好 了 必要 的 准备 。 

e@ 支持 通用 网 关 接口 CCGD: Apache 遵守 CGL1.1 标准 并 且 提 供 了 扩充 的 特征 ， 如 定制 
环境 变量 和 很 难 在 其 他 Web 服务 器 中 找到 的 调试 支持 功能 。 

e@ 支持 常见 的 网 页 编程 语言 : 可 支持 的 网 页 编程 语言 包括 Perl、PHP、Python 和 Java 
等 ， 支 持 各 种 常用 的 Web 编程 语言 ， 使 Apache 具有 更 广泛 的 应 用 领域 。 

e@ ”模块 化 设计 : 通过 标准 的 模块 实现 专 有 的 功能 ， 提 高 了 项 目 完成 的 效率 。 

e ”运行 非常 稳定 ， 同 时 具备 效率 高 、 成 本 低 的 特点 ， 而 且 具 有 良好 的 安全 性 。 


2.4.2 关闭 原 有 的 网 站 服务 器 


在 安装 Apache 网 站 服务 器 之 前 ， 如 果 所 使 用 的 操作 系统 已 经 安装 了 网 站 服务 器 ， 如 IIS 
网 站 服务 器 等 ， 用 户 必须 先 停止 这 些 服务 器 ， 才 能 正确 安装 Apache 网 站 服务 器 。 

以 Windows 7 的 操作 系统 为 例 ， 在 桌面 上 右 击 “ 我 的 电脑 ”图 标 ， 从 弹出 的 快捷 菜单 中 
选择 “管理 ”命令 ， 弹 出 “计算 机 管理 ”窗口 ， 在 左 侧 的 列表 中 展开 “服务 和 应 用 程序 ” 选 
项 ， 然 后 选择 “Internet 信息 服务 (IIS) 管 理 器 ”选项 ， 在 右 侧 的 列表 中 单 击 “ 停 止 ” 按 钮 ， 即 
可 停止 IS 服务 器 ， 如 图 2-20 所 示 。 

如 此 一 来 ， 原 来 的 服务 器 软件 即 失效 ， 不 再 工作 ， 也 不 会 与 接 下 来 的 Apache 网 站 服务 器 
产生 冲突 了 。 

当然 ， 如 果 用 户 的 系统 原来 就 没有 安装 IIS 等 服务 器 软件 ， 即 可 略 过 这 一 节 的 步 又， 直接 
往 下 执行 。 
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图 2-20 “计算 机 管理 ”窗口 
2.4.3 安装 Apache 


Apache 是 免费 软件 ， 用 户 可 以 从 官方 网 站 直接 下 载 。Apache 的 官方 网 站 为 : 


http://www.apache.org 


下 面 以 下 载 好 的 Apache 2.2 为 例 ， 讲 解 如 何 安装 Apache。 具 体操 作 步 又 如 下 。 

双击 Apache 安装 程序 ， 弹 出 软件 安装 的 欢迎 界面 ， 单 击 Next 按钮 ， 如 图 2-21 
所 示 。 

进入 Apache 许可 协议 界面 ， 选 择 “I accept the terms in the license agreement” 单 
选 按 钮 ， 然 后 单 击 Next 按钮 ， 如 图 2-22 所 示 。 
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the Installation Wizal Lcense Agreement 
HTTP Server 2.2.22 Please read the folowing Icense agreement carefi#iy. 


The botsloton Werd wl owed Ageche HTTP Server 2.2.22 
on your computer. To continue, dick Next 


Apache License ~ 
Version 2.0, January 2004 | 
|rERws AND CONDMONS FOR USE, REPRODUCTION, AND DISTRIBUTION 


1. Definitons. 
ee “License” shall mean the terms and conditons for use reproduction, and 
Mae ibution as defined by Sections 1 through 9 of this document 


© 1 accept the terms n the icense agreement 
D1 do not accept the terms n the icense agreement 
nstalshsed 
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图 2-21 软件 安装 的 欢迎 界面 2-22 Apache 许可 协议 界面 
进入 Apache 服务 器 注意 事项 界面 ， 单 击 Next 按钮 ， 如 图 2-23 所 示 。 


DZ 进入 服务 器 信息 设置 界面 ， 输 入 服务 器 的 一 些 基本 信息 ， 分 别 为 Network 
Domain( 网 络 域名 )、Server Name( 服 务 器 名 )、Administrator's Email Address( 管 理 员 信 
箱 )， 并 选择 Apache 的 工作 方式 。 如 果 只 是 在 本 地 计算 机 上 使 用 Apache， 前 两 项 可 
以 输入 “localhost”。 工 作 方式 建议 选择 第 一 项 : 针对 所 有 用 户 ， 工 作 端口 为 80， 
当 机 器 启动 时 自动 启动 Apache， 如 图 2-24 所 示 。 然 后 单 击 Next 按钮 。 


Read This First Server Information 
Read this Before Running Apache on Wndows. Please enter your servers nformation. 


Network Doman (e.g. somenet.com) 


Apache HTTP Sever 


E 
Whatis It? 

The Apache HTTP Server ls a powerful and flexible HTTP/1.1 compliant web server. Dver Nowe 和 0 web 
|Originally designed as a replacementforthe NCSAHTTP Server thas grown to be 


Admnistrators Emal Address (e.g. webmaster @somenet.com): 
osfesdfeaa152.com| 
Inatal Apache HTTP Server 22programs and shorteuts for: 


® for Al Users, on Port 80, as a Service —Recommended. 
© on for the Current User, on Port 8080, when started Manualy. 


Cm Jrea> | ene 


图 2-23 ”Apache 服务 器 注意 事项 界面 2-24 ”服务 器 信息 设置 界面 


EUD 进入 安装 类 型 界面 ， 其 中 Typical 为 典型 安装 ，Custom 为 自 定 义 安装 。 默 认 情 
况 下 ， 选 择 典 型 安装 即 可 ， 单 击 Next 按钮 ， 如 图 2-25 所 示 。 

END 进入 安装 路 径 选择 界面 ， 单 击 Change 按钮 ， 可 以 重新 设置 安装 路 径 ， 本 例 采 用 
默认 的 安装 路 径 ， 单 击 Next 按钮 ， 如 图 2-26 所 示 。 


Setup Type Destination Folder 
(Choose the setup type that best suts your needs. Chck Change to nstal to a different folder 


Please select a setup type. 重 Instal Apache HTTP Server 22to the folder; 
C:\Program Fles Wpache Software Foundation Wpache2.2\ 
© Typical 
体 Typical program features wl be nstaled, (Headers and Lbranes 
for compling modules wl not be nstaled.) 


© Custom 
Choose whch program features you want nstaled and where they 
wil be nstaled. Recommended for advanced users, 


Iinstalshield 


图 2-25 ”安装 类 型 界面 2-26 ”安装 路 径 选 择 界面 
进入 安装 准备 就 绪 界 面 ， 单 击 Install 按钮 ， 如 图 2-27 所 示 。 


ES 系统 开始 自动 安装 Apache 主 程序 ， 安 装 完成 后 ， 进 入 提示 信息 界面 ， 单 击 


Finish 按钮 完成 安装 ， 如 图 2-28 所 示 。 
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网 Apache HTTP Server 2.2- Installation Wizard [| 则 Apacdhe HTTP Server 22 - nstallation Wizard | 
Ready to Install the Program 由 Installation Wizard Completed 
The wizardis ready to begn installation. 
Chck Installto begn the nstalation. Instalation Wizard has successfully instaled Apache HTTP 


The 
If you want to review or change any of your installation settings, dick Back. Cick Cancel to op WN, 
the waard 


Instalshield 


图 2-27 安装 准备 就 绪 界面 2-28 ”Apache 安装 完成 


2.4.4 将 PHP 与 Apache 建立 关联 


Apache 安装 完成 后 ， 还 不 能 运行 PHP 网 页 ， 需 要 将 PHP 与 Apache 建立 关联 。 

Apache 的 配置 文件 名 称 为 httpd.conf， 这 是 纯 文 本 文件 ， 用 记事 本 即 可 打开 编辑 。 此 文件 
存放 在 Apache 安装 目录 的 Apache2\config\ 目 录 下 。 另 外 ， 也 可 以 通过 单 击 “ 开 始 ” 按 钮 ， 在 
弹出 的 菜单 中 选择 “所 有 程序 ”一 “Apache HTTP Server 2.2” 一 “Configure Apache Server” 
一 “Edit the Apache httpd conf Configuration File” 命 令 ， 如 图 2-29 所 示 。 

打开 Apache 配置 文件 后 ， 首 先 设 置 网 站 的 主 目录 。 本 书 将 案例 的 源 文 件 放 在 D 盘 的 
php5book 文件 夹 下 ， 所 以 设置 主 目录 为 d:/php5book/。 在 http.conf 文件 中 找到 DocumentRoot 
参数 ， 将 其 值 修改 为 d:/php5book/， 如 图 2-30 所 示 。 
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2-29 选择 Apache 配置 文件 2-30 设置 网 站 的 主 目录 


到 


然后 指定 php.ini 文件 的 存放 位 置 。 由 于 PHP 安装 在 d:\php5， 所 以 ，php.ini 的 位 置 为 
d:\php5Wphp.ini。 在 httpd.conf 配置 文件 中 的 任意 位 置 加 入 “PHPIniDir“d:\php5\php.ini*” 语 
句 ， 如 图 2-31 所 示 。 

最 后 ， 向 Apache 中 加 入 PHP 模块 。 在 httpd.conf 配置 文件 中 的 任意 位 置 加 入 3 行 语句 : 

LoadModule php5 module "d:/php5/php5apache2 2.d11" 

AddType application/x-httpd-php .php 

AddType application/x-httpd-php .html 

输入 效果 如 图 2-32 所 示 。 完 成 上 述 操 作 后 ， 保 存 httpd.conf 文件 ， 然 后 重启 Apache， 即 
可 使 设置 生效 。 
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图 2-31 指定 php.ini 文 件 的 存放 位 置 图 2-32 向 Apache 中 加 入 PHP 模板 


2.5 测试 第 一 个 PHP 程序 


上 面 讲述 了 两 种 服务 器 环境 的 搭建 方法 ， 读 者 可 以 根据 自己 的 需求 进行 选择 。 

下 面 通过 一 个 示例 ， 讲 解 如 何 编写 PHP 程序 并 运行 和 查看 效果 。 下 面 以 在 IIS 服务 器 环 
境 中 为 例 进行 讲解 。 

读者 可 以 使 用 任意 的 文本 编辑 软件 ， 如 记事 本 ， 新 建 名 称 为 “helloworld” 的 文件 ， 输 入 
以 下 代码 : 


<HTML> 

<HEAD> 

</HEAD> 

<BODY> 

<h2>PHP Hello World - 来 自 PHP 的 问候 。</h2> 

<?php 
echo "Hello, World."™; 
echo "你 好 世界 。"; 

?> 

</BODY> 

</HTML> 
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将 文件 保存 在 主 目录 或 虚拟 目录 下 ， 保 存 格式 为 php。 然 后 ， 在 浏览 器 的 地 址 栏 中 输入 
“http://localhost/helloworld.php”， 并 按 Enter 键 确认 ， 运 行 结 果 如 图 2-33 所 示 。 


寿 rapy/ocalhos PD ~ BO X| localhost 
文件 (有 帝 进 6) 坦 看 (V) 收藏 天 (A) 工具 (T) 帮助 (H) 


PHP Hello World - 来 自 PHP 的 


问候 。 


| Hello，World. 你 好 世界 。 


息 100% ~ 


2-33 第 一 个 PHP 程序 


案例 分 析 : 

(1) 其 中 “PHP Hello World - 来 自 PHP 的 问候 。” 是 HTML 中 的 “<HEAD><h2>PHP 
Hello World - 来 自 PHP 的 问候 。</h2></HEAD>” 代 码 所 生成 的 。 

(2) “Hello，World. 你 好 世界 。” 则 是 由 <?php echo“Hello，World.”; echo“ 你 好 世 
界 。” ?> 生成 的 。 

(3) 在 HTML 中 嵌入 PHP 代码 的 方法 即 是 在 <?php ?> 标识 符 中 间 填 入 PHP 语句 ， 语 句 
要 以 分 号 “;” 结 束 。 

(4) <?php ?> 标识 符 的 作用 ， 就 是 告诉 Web 服务 器 ，PHP 代码 从 什么 地 方 开始 、 到 什么 
地 方 结束 。<?php ?> 标识 符 内 的 所 有 文本 都 要 按照 PHP 语言 规范 进行 解释 ， 以 区 别 于 HTML 
代码 。 


2.6 疑难 解 惑 


疑问 1: 如 何 设置 网 站 的 主 目录 ? 


在 Windows 7 操作 系统 中 ， 设 置 网 站 主 目 录 的 方法 如 下 。 

利用 本 章 所 介绍 的 方法 ， 打 开 “ 计 算 机 管理 ”窗口 ， 选 择 “Default Web Site” 选 项 ， 如 
图 2-34 所 示 。 

在 右 侧 的 窗 格 中 单 击 “ 基 本 设置 ”链接 ， 弹 出 “编辑 网 站 ”对 话 框 ， 如 图 2-35 所 示 。 单 
击 物理 路 径 下 的 按钮 ， 即 可 在 弹出 的 对 话 框 中 重新 设置 网 站 的 主 目录 。 


疑问 2: 如 何 却 载 IIS? 


读者 经 常会 遇 到 IIS 不 能 正常 使 用 的 情况 ， 所 以 需要 首先 卸载 ITS， 然后 再 次 安装 即 可 。 
利用 本 章 的 方法 打开 “Windows 功能 ”窗口 ， 取 消 “Internet 信息 服务 ” 复 选 框 ， 单 击 
“确定 ”按钮 ， 系 统 将 自动 完成 IS 的 印 载 ， 如 图 2-36 所 示 。 


图 2-34 “Internet 信息 服务 ”窗口 图 2-35 “编辑 网 站 ”对 话 杠 


加 Internet Information Services 可 承 怠 的 Web 核心 
四 
田 贺 有 Microsoft .NET Framework 3.5.1 
回回 申 Microsoft Message Queue (MSMQ) 服务 器 


国 同 具 NFS 服务 
加 及 RAS 连接 管理 糙 管 理工 具 包 (CMAK) 
Eh Np A 
国 肯 Tablet PC 组 件 
固 且 Telnet 服务 器 
回 且 Teinet 者 户 流 
加 让 TFrp 者 户 注 


图 2-36 “Windows 功能 ”窗口 
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3.1 认识 PHP 标识 


默认 情况 下 ，PHP 是 以 <?php ?> 标识 符 为 开始 和 结束 标记 的 。 但 是 ，PHP 代码 有 不 同 的 
表示 风格 。 最 为 常用 的 风格 就 是 这 种 默认 方法 。 也 有 人 把 这 种 默认 风格 称 为 PHP 的 XML 风 
格 。 下 面 来 学 习 其 他 类 型 的 标识 风格 。 


3.1.1 短 风 格 


有 了 时候， 读者 会 看 到 一 些 代 码 中 出 现 用 <? ?> 标识 符 表示 PHP 代码 的 情况 。 这 种 就 是 所 谓 
的 “ 短 风格 ”(Short Style) 表 示 法 。 例 如 : 

<? echo "这 是 PHP 短 风格 的 表示 方式 。"?> 

这 种 表示 方法 在 正常 情况 下 并 不 推荐 。 并 且 在 php.ini 文件 中 ，short_open tags 设置 默认 
是 关闭 的 。 另 外 ， 以 后 提 到 的 一 些 功能 设置 会 与 这 种 表示 方法 相 冲 突 。 比 如 与 XML 的 默认 标 
识 符 相 冲 突 。 


3.1.2 script 风格 
有 的 编辑 器 对 PHP 代码 完全 采用 另外 一 种 表示 方式 ， 比 如 <script></script> 的 表示 方式 。 
例如 ， 


<script language="php"> 
echo "这 是 PHP 的 script 表示 方式 。"; 


</script> 


这 种 表示 方式 十 分 类 似 于 HTML 页 面 中 JavaScript 的 表示 方式 。 
3.1.3 ASP 风格 
受 ASP 的 影响 ， 为 了 照顾 ASP 使 用 者 对 PHP 的 使 用 ，PHP 提供 了 ASP 标志 风格 。 例 如 ， 


<% 
echo "这 是 PHP 的 ASP 的 表示 方式 。"; 
$s> 


这 种 表示 是 在 特殊 情况 下 使 用 的 ， 并 不 推荐 正常 使 用 。 


3.2 了 解 编码 规范 


由 于 现在 的 Web 开发 往往 是 多 人 一 起 合作 完成 的 ， 所 以 使 用 相同 的 编码 规范 显得 非常 重 
要 ， 特 别 是 新 的 开发 人 员 参 与 时 ， 往 往 需 要 知道 前 面 开 发 的 代码 中 变量 或 函数 的 作用 等 ， 如 
果 使 用 统一 的 编码 规范 ， 就 容易 多 了 。 


全’ 


3.2.1 什么 是 编码 规范 


编码 规范 规定 了 某 种 语言 的 一 系列 默认 编程 风格 ， 用 来 增强 这 种 语言 的 可 读 性 、 规 范 性 
和 可 维护 性 。 编 码 规范 主要 包 扩 语言 下 的 文件 组 织 、 缩 进 、 注 释 、 声 明 、 空 格 处 理 、 命 名 规 
则 等 。 

遵守 PHP 编码 规范 有 下 列 好 处 : 

e ”编码 规范 是 团队 开发 中 对 每 个 成 员 的 基本 要 求 。 对 编码 规范 遵循 得 好 坏 是 一 个 程序 

员 成 熟 程度 的 表现 。 

e ”能 够 提高 程序 的 可 读 性 ， 利 于 开发 人 员 互 相交 流 。 

e ”良好 一 致 的 编程 风格 在 团队 开发 中 可 以 达到 事半功倍 的 效果 。 

。 ”有 助 于 程序 的 维护 ， 可 以 降低 软件 成 本 。 


3.2.2 PHP 的 一 些 编码 规范 


PHP 作为 高 级 语言 的 一 种 ， 十 分 强调 编码 规范 。 以 下 是 规范 在 三 个 方面 的 体现 。 

1. 表述 

比如 在 PHP 的 正常 表述 中 ， 每 一 条 PHP 语句 都 是 以 “;” 结 尾 ， 这 个 规范 就 告诉 PHP 要 
执行 此 语句 。 例 如 : 


<?php 
echo "PHP 以 分 号 表示 语句 的 结束 和 执行 。"; 


es 

2. 空白 

PHP 对 空格 、 回 车 造成 的 新 行 、Tab 等 留 下 的 空白 的 处 理 也 遵循 编码 规范 。PHP 对 它们 
都 进行 忽略 。 这 跟 浏览 器 对 HTML 语言 中 的 空白 的 处 理 是 一 样 的 。 

3. 注释 

为 了 增强 可 读 性 ， 在 很 多 情况 下 ， 程 序 员 都 需要 在 程序 语句 的 后 面 添加 文字 说 明 。 这 些 
注释 的 风格 有 几 种 ， 分 别 是 C 语言 风格 、C++ 风 格 和 Shell 风格 。 

(1) C 语 言 风格 。 例 如 : 

/* 这 是 c 语言 风格 的 注释 内 容 */ 

这 种 方法 还 可 以 多 行使 用 。 例 如 : 

/* 这 是 

C 语言 风格 


的 注释 内 容 
吃 浊 


a 
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(2) C++ 风格 。 例 如 : 

// 这 是 c++ 风格 的 注释 内 容 行 一 

// 这 是 c++ 风格 的 注释 内 容 行 二 

这 种 方法 只 能 一 句 注释 占用 一 行 。 使 用 时 可 单独 一 行 ， 也 可 以 使 用 在 PHP 语句 之 后 的 同 
一 行 。 

(3) Shell 风格 。 例 如 : 

# 这 是 Shel11 风格 的 注释 内 容 


这 种 方法 只 能 一 句 注释 占用 一 行 。 使 用 时 可 单独 一 行 ， 也 可 以 使 用 在 PHP 语句 之 后 的 同 


、 


上 


3.3 常 量 
在 PHP 中 ， 常 量 是 一 旦 声明 就 无 法 改变 的 值 。 本 节 来 讲述 如 何 声 明和 使 用 常量 。 
3.3.1 声明 和 使 用 常量 


PHP 通过 define() 命 令 来 声明 常量 。 格 式 如 下 : 
define ("常量 名 "， 常 量 值 ) ; 


常量 名 是 一 个 字符 串 ， 往 往 在 PHP 编码 规范 的 指导 下 使 用 大 写 的 英文 字符 来 表示 。 例 如 
CLASS_NAME、MYAGE 等 。 


常量 值 可 以 是 很 多 种 PHP 数据 类 型 的 ， 可 以 是 数组 ， 可 以 是 对 象 ， 当 然 也 可 以 是 字符 和 
数字 。 

常量 就 像 变 量 一 样 储存 数值 ， 但 是 ， 与 变量 不 同 的 是 ， 常 量 的 值 只 能 设 定 一 次 ， 并 且 无 
论 在 代码 的 任何 位 置 ， 它 都 不 能 被 改动 。 

常量 声明 后 具有 全 局 性 ， 函 数 内 外 都 可 以 访问 。 

【 例 3.1】( 示 例文 件 ch03\3.1.php) 


<HTML> 
<HEAD> 
<TITLE> 自 定义 变量 </TITLE> 
</HEAD> 
<BODY> 
<?php 
define ("HUANY", "欢迎 学 习 PHP 基本 语法 知识 ") ; 
echo HUANY; 
?> 
</BODY> 
<HTML> 


本 程序 的 运行 结果 如 图 3-1 所 示 。 


碟 hapy/localhost DP- CX 
文件 (F) ” 畴 弗 (6]。 坦 看 (V) 收音 夫 (A) 工具 (T) 帮助 (H) 


欢迎 学 习 PHP 基 本 语法 知识 


3-1 声明 和 使 用 常量 


案例 分 析 : 
(1) 用 define 函数 声明 一 个 常量 。 而 常量 的 全 局 性 体现 在 可 在 函数 内 外 进行 访问 。 
(2) 常量 只 能 储存 布尔 值 、 整 型 、 浮 点 型 和 字符 串 数据 。 


3.3.2 ”使 用 内 置 常 量 

PHP 的 内 置 常量 是 指 PHP 在 语言 内 部 预先 定义 好 的 一 些 量 。PHP 中 预定 了 很 多 系统 内 置 
常量 ， 这 些 常 量 可 以 被 随时 调用 。 例 如 ， 下 面 是 一 些 常 见 的 内 置 常 量 。 

让 


这 个 默认 常量 是 PHP 程序 文件 名 。 若 引用 文件 (include 或 require)， 则 在 引用 文件 内 的 该 
常量 为 引用 文件 名 ， 而 不 是 引用 它 的 文件 名 。 


2._LINE_ 


这 个 默认 常量 是 PHP 程序 行 数 。 若 引用 文件 (include 或 require)， 则 在 引用 文件 内 的 该 常 
量 为 引用 文件 的 行 数 ， 而 不 是 引用 它 的 文件 的 行 数 。 


3. PHP_VERSION 
这 个 内 建 常量 是 PHP 程序 的 版 本 ， 如 “3.0.8-dev”。 

4.PHP_OS 

这 个 内 建 常量 指 执行 PHP 解析 器 的 操作 系统 名 称 ， 如 “Linux*。 
5. TRUE 

这 个 常量 就 是 真 值 (true)。 

6. FALSE 

这 个 常量 就 是 伪 值 (false)。 

7.E ERROR 

这 个 常量 指 到 最 近 的 错误 处 。 


重 
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8.E WARNING 
这 个 常量 指 到 最 近 的 警告 处 。 
9.E_PARSE 
该 常量 为 解析 语法 有 潜在 问题 处 。 
10.E NOTICE 
这 个 量 为 发 生 异 常 (但 不 一 定 是 错误 ) 处 。 例 如 存 取 一 个 不 存在 的 变量 。 
下 面 举例 说 明 系 统 常量 的 使 用 方法 。 
【 例 3.2】( 示 例文 件 ch033.2 php) 
<HTML> 
<HEAD> 
<TITLE> 系 统 变量 </TITLE> 
</HEAD> 
<BODY> 
<?php 
echo(__FILE ); 
SN echo "<p>"; 


echo(_ LINE ) 7 
echo "<p>"; 
echo (PHP_ VERSION); 
echo "<p>"; 
echo (PHP_OS); 

> 

</BODY> 

<HTML> 


本 程序 的 运行 结果 如 图 3-2 所 示 。 


3-2 ”使 用 内 置 常量 


案例 分 析 : 
(1) echo “<p>” 语 句 表示 为 输出 换行 。 


(2) echo(_FILE“) 语 句 输出 文件 的 文件 名 ， 包 括 详细 的 文件 路 径 。echo(_LINE_“) 语 句 
输出 该 语句 所 在 的 行 数 。echo(PHP_VERSION) 语 句 输出 PHP 程序 的 版 本 。echo(PHP_OS) 语 句 
输出 执行 PHP 解析 器 的 操作 系统 名 称 。 


3.4 变 量 


变量 像 是 一 个 贴 有 名 字 标 签 的 空 合子。 不同 的 变量 类 型 对 应 不 同 种 类 的 数据 ， 就 像 不 同 
种 类 的 东西 要 放 入 不 同 种 类 的 盒子 一 样 。 


3.4.1 PHP 中 的 变量 声明 


与 C 或 Java 语言 中 不 同 的 是 ，PHP 中 的 变量 是 弱 类 型 的 。 在 C 或 Java 中 ， 需 要 对 每 一 
个 变量 声明 类 型 ， 而 在 PHP 中 不 需要 这 样 做 。 这 是 极其 方便 的 。 

PHP 中 的 变量 一 般 以 “$” 作 为 前 级 ， 然 后 以 字母 a-z 的 大 小 写 或 者 “ ”下 划 线 开头 。 
这 是 变量 的 一 般 表示 。 

合法 的 变量 名 可 以 是 : 


$hello 
$Aforml 
$_formhandler 


非法 的 变量 名 如 : 


$168 
$!11like 


3.4.2 ”可 变 变量 和 变量 的 引用 


一 般 的 变量 很 容易 理解 ， 但 是 有 两 种 变量 的 概念 比较 难于 理解 ， 这 就 是 可 变 变 量 和 变量 
的 引用 。 我 们 通过 下 面 的 例子 对 它们 进行 学 习 。 
【 例 3.3】( 示 例文 件 ch03\3.3.php) 


<HTML> 
<HEAD> 
<TITLE> 系 统 变 量 </TITLE> 
</HEAD> 
<BODY> 
<?php 
$value0 = "guest"; 
$$value0 = "customer"; 
echo $guest."<br />"; 
$guest = "feifei"; 
echo $guest."\t".$$value0."<br />"; 
$valuel = "xiaoming"; 
$value2 = &$valuel; 
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echo $valuel."\t".$value2."<br />"; 
$value2 = "lili"; 
echo $valuel."\t".$value2; 

?> 


</BODY> 
<HTML> 
本 程序 运行 结果 如 图 3-3 所 示 。 
愿 httpy/localhost 只 - 昌 上 X | 关系 统 交 时 
文件 (F) ”编辑 (E) 前 看 (V) 收藏 天 (A) 工具 (T) 帮助 (H) 
| customer 
feifei feifei 
xiaoming xiaoming 
| 1ili 1ili 
图 3-3 使 用 可 变 变量 和 变量 的 引用 
案例 分 析 : 


(1) 在 代码 的 第 一 部 分 中 ，$value0 被 赋值 为 guest。 而 $value0 相当 于 guest， 则 $$value0 
相当 于 $guest。 所 以 当 $$value0 被 赋值 为 customer 时 ， 打 印 $guest 就 得 到 customer。 反 之 ， 当 
$guest 变量 被 赋值 为 feifei 时 ， 打 印 $$value0 同样 得 到 feifei。 这 就 是 可 变 变量 。 

(2) 在 代码 的 第 二 部 分 中 ，S$valuel 被 赋值 为 xiaoming， 然 后 通过 “&” 引 用 变量 $valuel 
并 赋值 给 $value2。 而 这 一 步 的 实质 是 ， 给 变量 $valuel 添加 了 一 个 别名 $value2。 所 以 打印 时 ， 
都 得 出 原始 赋值 xiaoming。 由 于 $value2 是 别名 ， 与 $valuel 指 的 是 同一 个 变量 ， 所 以 $value2 
被 赋值 为 lili 后 ，$valuel 和 $value2 都 得 到 新 值 lili。 

(3) 可 变 变 量 其 实 是 允许 改变 一 个 变量 的 变量 名 。 人 允许 使 用 一 个 变量 的 值 作为 另外 一 个 
变量 的 名 。 

(4) 变量 引用 相当 于 给 变量 添加 了 一 个 别名 。 用 “&” 来 引用 变量 。 其 实 两 个 变量 名 指 
的 都 是 同一 个 变量 。 就 像 是 给 同一 个 盒子 贴 了 两 个 名 字 标 签 ， 两 个 名 字 标 签 指 的 都 是 同一 个 
辣子 。 


3.4.3 ”变量 作用 域 


所 谓 变量 作用 域 (Scope)， 是 指 特定 变量 在 代码 中 可 以 被 访问 到 的 位 置 。 在 PHP 中 ， 有 6 
种 基本 的 变量 作用 域 法 则 。 

。 ”内 置 超 全 局 变量 : 在 代码 中 的 任意 位 置 都 可 以 访问 到 。 

日 ”常数 : 一 旦 声明 ， 它 就 是 全 局 性 的 。 可 以 在 函数 内 外 使 用 。 


a 


。 ”全 局 变量 : 在 代码 中 声明 ， 可 在 代码 中 访问 ， 但 是 不 能 在 函数 内 访问 。 

e ”在 函数 中 声明 为 全 局 变量 的 变量 : 就 是 同名 的 全 局 变量 。 

@ ”在 函数 中 创建 和 声明 为 静态 变量 的 变量 : 在 函数 外 是 无 法 访问 的 ， 但 是 这 个 静态 变 
量 的 值 是 得 以 保留 的 。 

e ”在 函数 中 创建 和 声明 的 局 部 变量 : 在 函数 外 是 无 法 访问 的 ， 并 且 在 本 函数 终止 时 终 
止 并 退出 。 


1. 超 全 局 变量 


超 全 局 变量 英文 是 Superglobal 或 者 Autoglobal( 自 动 全 局 变量 )。 这 种 变量 的 特性 是 ， 不 管 
在 程序 的 任何 地 方 都 可 以 访问 ， 也 不 管 是 函数 内 或 是 函数 外 ， 都 可 以 访问 。 而 这 些 “ 超 全 局 
变量 ”就 是 由 PHP 预先 定义 好 ， 以 方便 使 用 的 。 
这 些 “ 超 全 局 变量 ”或 “自动 全 局 变量 ”如 下 所 示 。 
$GLOBALS: 包含 全 局 变量 的 数组 。 
$_GET: 包含 所 有 通过 GET 方法 传递 给 代码 的 变量 的 数组 。 
$_POST: 包含 所 有 通过 POST 方法 传递 给 代码 的 变量 的 数组 。 
$_FILES: 包含 文件 上 传 变量 的 数组 。 
$_COOKIE: 包含 cookie 变量 的 数组 。 
$_SERVER: 包含 服务 器 环境 变量 的 数组 。 
$_ENV: 包含 环境 变量 的 数组 。 
$_REQUEST: 包含 用 户 所 有 输入 内 容 的 数组 (包括 $S_GET、$_ POST 和 $_COOKIE)。 
$_SESSION: 包含 会 话 变量 的 数组 。 


2. 全 局 变量 


全 局 变量 其 实 就 是 在 函数 外 声明 的 变量 ， 在 代码 中 都 可 以 访问 。 但 是 在 函数 内 是 不 能 访 
问 的 。 这 是 因为 函数 默认 就 不 能 访问 在 其 外 部 的 全 局 变量 。 

下 面 通过 例子 介绍 全 局 变量 的 使 用 方法 和 技巧 。 

【 例 3.4】( 示 例文 件 ch03\3.4.php) 


<HTML> 
<HEAD> 
<TITLE> </TITLE> 
</HEAD> 
<BODY> 
<?php 
$room = 20; 
function showrooms(){ 
echo $room; 
showrooms (); 
echo $room.' 间 房间 。'; 
2> 
</BODY> 
<HTML> 


谤 入 半 上 有 严 dHd_ 才 g 外 人 
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本 程序 运行 结果 如 图 3-4 所 示 。 


【¢ 加 ET 总 localhost x Wn 
文件 中。 编辑 (E) ”可 看 (V) 收藏 天 (A) 工具 (帮助 (H) 


Callstack 
|# Time Memory Function Location 

1| 0.0011 | 139448| {main} ( ) | \3.4.php:0 

2| 0.0011 | 139816|showrooms( ) | \3.4.php:11 

20 间 房间 。 加 


或 100% ~ 


图 3-4 使 用 全 局 变量 


案例 分 析 : 

出 现 上 述 结果 ， 是 因为 函数 无 法 访问 到 外 部 全 局 变量 ， 但 是 在 代码 中 都 可 以 访问 全 局 变 
量 。 如 果 想 让 函数 访问 某 个 全 局 变量 ， 可 以 在 函数 中 通过 global 关键 字 来 声明 。 就 是 说 ， 要 
告诉 函数 ， 它 要 调用 的 变量 是 一 个 已 经 存在 或 者 即将 创建 的 同名 全 局 变量 ， 而 不 是 默认 的 本 
地 变量 。 

下 面 通过 例子 介绍 使 用 global 关键 字 的 方法 和 技巧 。 

【 例 3.5】( 示 例文 件 ch03\3.5.php) 


<HTML> 
<HEAD> 
<TITLE> </TITLE> 
</HEAD> 
<BODY> 
<?php 
Sroom = 20; 
function showrooms ()1{ 
global $room; 
echo $room. ' 间 新 房间 。<br />'; 
. 
Showrooms (); 
echo $room.' 间 房间 。'; 
23> 
</BODY> 
<HTML> 


本 程序 运行 结果 如 图 3-5 所 示 。 


"x 


€ OT 


20 间 新 房间 。 
20 间 房间 。 


图 3-5 使 用 global 关键 字 


另外 ， 读 者 还 可 以 通过 “ 超 全 局 变量 ”中 的 SGLOBALS 数组 进行 访问 。 
下 面 的 例子 介绍 如 何 使 用 GLOBALS 数组 。 
【 例 3.6】( 示 例文 件 ch03\3.6.php) 


<HTML> 

<HEAD> 
<TITLE> </TITLE> 

</HEAD> 

<BODY> 

<?php 

$room = 20; 

function showrooms(){ 
$room = $GLOBALS['room']; 
echo $room.' 间 新 房间 。<br />'; 


} 
showrooms (); 


echo $room.' 间 房间 。'; 


3 
</BODY> 

<HTML> 

本 程序 运行 结果 如 图 3-6 所 示 。 


20 间 新 房间 。 


20 间 房间 。 


图 3-6 使 用 GLOBALS 数组 
结果 与 前 面 的 例子 完全 相同 ， 可 见 两 种 方法 都 可 以 实现 同一 个 效果 。 
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3. 静态 变量 


静态 变量 只 在 函数 内 存在 ， 函 数 外 无 法 访问 。 但 是 执行 后 ， 其 值 保留 。 

也 就 是 说 ， 这 一 次 执行 完毕 后 ， 这 个 静态 变量 的 值 保留 ， 下 一 次 再 执行 此 函数 ， 这 个 值 
还 可 以 调用 。 

通过 下 面 的 例子 介绍 静态 变量 的 使 用 方法 和 技巧 。 

【 例 3.7】( 示 例文 件 ch03\3.7.php) 


<HTML> 

<HEAD> 
<TITLE> 静 态 变 量 </TITLE> 

</HEAD> 

<BODY> 

<?php 

$person = 207 

function showpeople(){ 
static $person = 5; 
$persont++; 
echo ' 再 增加 一 位 ， 将 会 有 ' .Sperson.' 位 static 人 员 。<br />'; 

} 

showpeople () 7 

echo $person.' 人 员 。<br />'; 

showpeople () 

ey 

</BODY> 

<HTML> 


本 程序 运行 结果 如 图 3-7 所 示 。 


[@ tuo/ocalhot 2 » BOx| 


再 增加 一 位 ， 将 会 有 6 位 statie 人 员 。 
20 人 员 。 
再 增加 一 位 ， 将 会 有 7 位 static 人 员 。 


图 3-7 使 用 静态 变量 


案例 分 析 : 

(1) 其 中 函数 外 的 echo 语句 无 法 调用 函数 内 的 static Sperson， 它 调用 的 是 $person = 20。 

(2) 另外 ，showpeople0 函 数 被 执行 了 两 次 ， 这 个 过 程 中 ，static $person 的 运算 值得 以 保 
留 ， 并 且 通 过 $person++ 进 行 了 累加 。 


前 ， 


3.5 理解 变量 的 类 型 


从 PHP 4 开始 ，PHP 中 的 变量 不 需要 事先 声明 ， 赋 值 即 声明 。 声 明和 使 用 这 些 数据 类 型 
读者 需要 了 解 它们 的 含义 和 特性 。 下 面 介绍 整 型 、 浮 点 型 、 布 尔 值 和 两 个 较 特 殊 类 型 。 


3.5.1 什么 是 类 型 


量 只 
量 赋 


不 同 的 数据 类 型 其 实 就 是 所 储存 数据 的 不 同 种 类 。PHP 主要 有 下 列 数据 类 型 。 
整 型 (integeD: 用 来 储存 整数 。 

浮 点 型 (float): 用 来 储存 实数 。 

字符 串 (string): 用 来 储存 字符 串 。 

布尔 值 (boolean): 用 来 储存 真 (true) 或 假 (false)。 

数组 (array): 用 来 储存 一 组 数据 。 

@ 对象 (objecb: 用 来 储存 一 个 类 的 实例 。 

作为 弱 类 型 语言 ，PHP 也 被 称 为 动态 类 型 语言 。 在 强 类 型 语言 中 (例如 C 语言 )， 一 个 变 
能 储存 一 种 类 型 的 数据 ， 并 且 这 个 变量 在 使 用 前 必须 声明 变量 类 型 。 而 在 PHP 中 ， 给 变 
什么 类 型 的 值 ， 这 个 变量 就 是 什么 类 型 的 。 例 如 以 下 几 个 变量 : 

$hello = 'hello world'; 

// 由 于 'hello world' 是 字符 串 ， 则 变量 $hello 的 数据 类 型 就 为 字符 串 类 型 

hello = 100; 

亨 计 100 为 整 型 ， 所 以 $hello 也 就 为 整 型 


$wholeprice = 100.0; 
// 由 于 100.0 为 浮 点 型 ， 所 以 $wholeprice 就 是 浮 点 型 


由 此 可 见 ， 对 于 变量 而 言 ， 如 果 没有 定义 变量 的 类 型 ， 则 它 的 类 型 由 所 赋值 的 类 型 来 决定 。 


3.5.2 ” 整 型 (integen) 


整 型 是 数据 类 型 中 最 为 基本 的 类 型 。 在 32 位 的 运算 中 ， 整 型 的 取 值 范围 是 -2147483648 


~+2147483647。 整 型 可 以 表示 为 十 进 制 、 十 六 进 制 和 八进制 数 。 


3.5 


值 范 


例如 : 


3560 ”// 十 进 制 整数 
01223 ”// 八 进 制 整数 
0x1223 ”// 十 六 进 制 整数 


.3 浮 点 型 (float 或 double) 


浮 点 型 就 是 实数 。 在 大 多 数 运行 平台 下 ， 这 个 数据 类 型 的 大 小 为 8 个 字 节 。 它 的 近似 取 
目 是 2.2E-308 ~ 1.8E+308( 科 学 计数 法 )。 
例如 : 


下游 补 江村 dHd_ 协 8 名 轩 


py A 
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3.5.4 布尔 型 (boolean) 


布尔 型 只 有 两 个 值 ， 就 是 tue 和 false。 布 尔 型 是 十 分 有 用 的 数据 类 型 ， 通 过 它 ， 程 序 实 
现 了 逻辑 判断 的 功能 。 

而 对 于 其 他 的 数据 类 型 ， 基 本 都 有 布尔 属性 。 

e@ 整 型 : 为 0 时 ， 其 布尔 属性 为 false， 为 非 零 值 时 ， 其 布尔 属性 为 true。 

@ 浮 点 型 : 为 0.0 时 ， 其 布尔 属性 为 false， 为 非 零 值 时 ， 其 布尔 属性 为 rue。 

ee 字符 串 型 : 空 字符 串 “”， 或 者 零 字 符 串 “0” 时 ， 为 false， 包 含 除 此 以 外 的 字符 串 

时 为 true。 

e@ ”数组 型 ， 若 不 含 任何 元 素 ， 为 false， 只 要 包含 元 素 ， 则 为 tue。 

@ 对象 型 、 资 源 型 ， 永远 为 tue。 

e@ 空 型 ， 永远 为 false。 


3.5.5 字符 串 型 (string) 


字符 串 型 的 数据 是 引号 之 间 的 一 串 字符 。 引 号 有 双 引 号 “和 单 引号 “两 种 。 

但 是 这 两 种 表示 也 有 一 定 的 区 别 。 

双 引 号 几乎 可 以 包含 所 有 的 字符 。 但 是 其 中 显示 的 变量 的 值 ， 而 不 是 变量 的 名 。 而 有 些 
特殊 字符 在 使 用 时 需要 加 上 “\” 这 一 转 义 符号 。 

单 引号 内 的 字符 是 被 直接 表示 出 来 的 。 

下 面 通过 一 个 例子 来 讲述 上 面 $ 种 类 型 的 使 用 方法 和 技巧 。 

【 例 3.8】( 示 例文 件 ch03\3.8.php) 


<HTML> 
<HEAD> 

<TITLE> 变 量 的 类 型 </TITLE> 
</HEAD> 
<BODY> 
<?php 

$intl = 2012; 
$int2 = 01223; ”// 八 进 制 整数 
$int3 = 0x1223; ”// 十 六 进 制 整数 
echo "输出 整数 类 型 的 值 : "; 
echo $intl; 
echo "\t"; // 输 出 一 个 制 表 符 
echo $int2;  // 输 出 659 
Soho "NE 
echo $int3;  // 输 出 4643 
echo "<br>"; 
$floatl = 54.66; 


echo $float1l;  // 输 出 54.66 
echo "<br>"; 
echo "输出 布尔 型 变量 : "7 
echo (Boolean) ($int1); // 将 intl 整 型 转化 为 布尔 变量 
echo "<br>"; 
$stringl = "字符 串 类 型 的 变量 "; 
echo $stringl; 
?> 
</BODY> 
<HTML> 


本 程序 的 运行 结果 如 图 3-8 所 示 。 


【€ 罗 


| 输出 整数 类 型 的 值 : 2012 659 4643 
54.66 

| 输出 布尔 型 变量 : 1 
字符 串 类 型 的 变量 


图 3-8 使 用 各 种 数据 类 型 


3.5.6 ”数组 型 (array) 


数组 是 PHP 变量 的 集合 ， 它 是 按照 “ 键 ” 与 “ 值 ”对 应 的 关系 组 织 数据 的 。 数 组 的 键 可 
以 是 整数 ， 也 可 以 是 字符 串 。 

在 默认 情况 下 ， 数 组 元 素 的 键 为 从 零 开始 的 整数 。 

在 PHP 中， 使 用 listO 函 数 或 arrayO 函 数 来 创建 数组 ， 也 可 以 直接 进行 赋值 。 

下 面 使 用 array0 函 数 创建 数组 。 

【 例 3.9】( 示 例文 件 ch03\3.9.php) 


<HTML> 
<HEAD> 
<TITLE> 数 组 变量 </TITLE> 
</HEAD> 
<BODY> 
<?php 
$arr=array 
( 
0=>15, 
2=>1E+05, 
1=>" 开 始 学 习 PHP 基本 语法 了 "， 
ba 
for ($i=0; $i<count ($arr); Si++) 
{ 


3@ 
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$arrl = each ($arr); 
echo "$arrl[value]<br>"; 


} 


六 


</BODY> 
<HTML> 
本 程序 的 运行 结果 如 图 3-9 所 示 。 
改口 -| 区: 
(¢ 回 鲁 htpi/localhost DP ~ SOx||@ 

文件 (有 ”编辑 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 

15 

100000 

开始 学 习 PHP 基 本 语法 了 

图 3-9 使 用 array() 函 数 创建 数组 
案例 分 析 : 
(1) 程序 中 用 => 为 数组 赋值 ， 数 组 的 下 标 只 是 存储 的 标识 ， 没 有 任何 其 他 意义 ， 数 组 元 
素 的 排列 以 加 入 的 先后 顺序 为 准 。 


(2) 本 程序 采用 for 循环 语句 输出 整个 数组 ， 其 中 count 函数 返回 数组 的 个 数 ，echo 函数 
当前 数组 指针 的 索引 / 值 对 ， 后 面 章 节 中 将 详细 讲述 函数 的 使 用 方法 。 

上 面 例子 中 的 语句 可 以 简化 如 下 。 

【 例 3.10】( 示 例文 件 ch03\3.10.php) 


<HTML> 
<HEAD> 
<TITLE> 数 组 变量 </TITLE> 
</HEAD> 
<BODY> 
<?php 
$arr = array (15,1E+05, "开始 学 习 PHP 基本 语法 了 ") ; 
for ($1i=0; $i<3; $i++) 
{ 
echo $arr[$i]<br>"; 
. 
2 
</BODY> 
<HTML> 


本 程序 运行 结果 如 图 3-10 所 示 。 
从 结果 可 以 看 出 ， 两 种 写法 的 运行 结果 完全 一 样 。 


返 


可 


15 
100000 


开始 学 习 PHP 基 本 语法 了 


3-10 ”简化 后 的 程序 运行 结果 


另外 ， 读 者 还 可 以 对 数组 的 元 素 一 个 一 个 地 赋值 ， 下 面 举例 说 明 。 上 面 的 程序 中 的 语句 
可 以 写成 如 下 形式 。 
【 例 3.11】( 示 例文 件 ch03\3.11.php) 


<HTML> 
<HEAD> 
<TITLE> 数 组 变量 </TITLE> 
</HEAD> 
<BODY> 
<?php 
$arr[0] = 15; 
$arr[2] = 1E+05; 
$arr[1] = "开始 学 习 PHP 基本 语法 了 "; 
for ($i=0; $i<count ($arr); $i++) 
{ 
$arrl = each ($arr); 
echo "$arrl[value]<br>"; 
3 
时 
</BODY> 
<HTML> 


本 程序 运行 结果 如 图 3-11 所 示 。 


| 
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图 3-11 逐个 赋值 时 的 程序 运行 结果 
从 结果 可 以 看 出 ， 一 个 一 个 赋值 的 方法 与 上 面 两 种 写法 的 运行 结果 是 一 样 的 。 


全 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 一 


3.5.7 “对象 型 (object) 


对 象 就 是 类 的 实例 。 当 一 个 类 被 实例 化 以 后 ， 这 个 生成 的 对 象 被 传递 给 一 个 变量 ， 这 个 
变量 就 是 对 象 型 变量 。 对 象 型 变量 也 属于 资源 型 变量 。 


3.5.8 NULL 型 


NULL 类 型 用 来 标记 一 个 变量 为 空 。 但 一 个 空 字符 串 与 一 个 NULL 是 不 同 的。 在 数据 库 
存储 时 ， 会 把 空 字 符 串 和 NULL 区 分 开 处 理 。NULL 型 在 布尔 判断 时 永远 为 false。 很 多 情况 
下 ， 在 声明 一 个 变量 的 时 候 可 以 直接 先 赋值 为 NULL 型 ， 如 $value = NULL。 


3.5.9 ”资源 类 型 (Resource) 


Resources 类 型 就 是 资源 类 型 ， 它 也 是 十 分 特殊 的 数据 类 型 ， 表 示 了 PHP 的 扩展 资源 ， 它 
可 以 是 一 个 打开 的 文件 ， 可 以 是 一 个 数据 库 连 接 ， 甚 至 可 以 是 其 他 数据 类 型 。 但 是 在 编程 过 
程 中 ， 资 源 类 型 却 是 几乎 永远 接触 不 到 的 。 


3.5.10 数据 类 型 之 间 的 相互 转换 


数据 从 一 个 类 型 转换 到 另外 一 个 类 型 ， 就 是 数据 类 型 转换 。 在 PHP 语言 中 ， 有 两 种 常见 
的 转换 方式 : 自动 数据 类 型 转换 和 强制 数据 类 型 转换 。 


1. 自动 数据 类 型 转换 


这 种 转换 方法 最 为 常用 。 直 接 输 入 数据 的 转换 类 型 即 可 。 

例如 ，float 型 转换 为 整数 int 型 ， 小 数 点 后 面 的 数 将 被 舍弃 。 如 果 float 数 超过 了 整数 的 
取 值 范围 ， 则 结果 可 能 是 0 或 者 整数 的 最 小 负数 。 

【 例 3.12】( 示 例文 件 ch03\3.12.php) 


<HTML> 

<HEAD> 
<TITLE> 自 动 数据 类 型 转换 </TITLE> 

</HEAD> 

<BODY> 

<?php 

E16l = L067 

echo (int)$fl01."<br>"; 

$flo2 = 4E32; // 超 过 整数 取 值 范围 

echo (int) $flo2; 

2 

</BODY> 

<HTML> 


程序 运行 结果 如 图 3-12 所 示 。 


图 3-12 ”自动 数据 类 型 转换 


2. 强制 数据 类 型 转换 
在 PHP 中 ， 可 以 使 用 setType 函数 强制 转换 数据 类 型 。 基 本 语法 如 下 : 


Bool setType(var, string type) 


i type 的 可 能 值 不 能 包含 资源 类 型 数据 . 
意 


【 例 3.13】( 示 例文 件 ch03\3.13.php) 


<HTML> 
<HERD> 
<TITLE> 强 制 数据 类 型 转换 </TITLE> 
</HEAD> 
<BODY> 
<?php 
Sflol = TL.868 
echo setType ($flol, "int"); 
?> 
</BODY> 
<HTML> 


程序 运行 结果 如 图 3-13 所 示 。 


NN 
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图 3-13 ”使 用 强制 类 型 转换 


3.6 学习 使 用 运算 符 


PHP 包含 三 种 类 型 的 运算 符 。 一 元 运算 符 、 二 元 运算 符 和 三 元 运算 符 。 一 元 运算 符 用 在 
一 个 操作 数 之 前 ， 二 元 运算 符 用 在 两 个 操作 数 之 间 ， 三 元 运算 符 是 作用 在 三 个 操作 数 之 间 。 


4 使 
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3.6.1 算术 运算 符 


算术 运算 符 是 最 简单 ， 也 是 最 常用 的 运算 符 。 常 见 的 算术 运算 符 如 表 3-1 所 示 。 
表 3-1 常用 运算 符 


【 例 3.14】( 示 例文 件 ch03\3.14.php) 


<HTML> 

<HEAD> 
<TITLE> 算 术 运 算 符 </TITLE> 

</HEAD> 

<BODY> 

<?php 
$a=13; 
$b=2; 
echo $a."+".$b."="; 
echo $a+$b."<br>"; 
echo $a."-".$b."="; 
echo $a-$b."<br>"; 
echo Sa"*™" $b"="p 
echo $a*$b."<br>"; 
echo $a."/".$b."="; 
echo $a/$b."<br>"; 
echo $a."%".$b."="; 
echo $a%s$b."<br>"; 
echo $a."++"."="} 
echo $at+t+."<br>"; 


Scho Sa"—="2 "= 
eoho Sa=— -<br> 
?> 
</BODY> 
<HTML> 


程序 运行 结果 如 图 3-14 所 示 。 


ee w/ten po- nox| Smrams | 


13+2=15 
13-2=11 
13*2=26 
13/2=6.5 
13%2=1 
13++=13 
14--=14 


图 3-14 ”使 用 算术 运算 符 


Se 除了 数值 可 以 进行 自 增 运 算 外 ， 字 符 也 可 以 进行 自 增 运 算 操作 。 例 如 b++， 结 果 


NE 将 等 于 c。 


3.6.2 ”字符 串 连接 符 


字符 运算 符 “.” 把 两 个 字符 串 连接 起 来 ， 变 成 一 个 字符 串 。 如 果 变 量 是 整 型 或 浮 点 型 ， 
PHP 也 会 自动 地 把 它们 转换 为 字符 串 输出 。 
【 例 3.15】( 示 例文 件 ch03\3.15.php) 


<HTML> 
<HEAD> 

<TITLE> 算 术 运 算 符 </TITLE> 
</HEAD> 
<BODY> 
<?php 

$a = "把 两 个 字符 串 "; 

Sp = 108208 

echo $a." 连 接 起 来 ，" .$b." 天 。"; 
人 
</BODY> 
<HTML> 


程序 运行 结果 如 图 3-15 所 示 。 


S 
\ 


¢ rrr Cr 


把 两 个 字符 串 连接 起 来 ，10. 25 天 。 


图 3-15 “使 用 字符 串 连接 符 


‘全 
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案例 课堂 >… 
3.6.3 ”赋值 运算 符 
赋值 运算 符 的 作用 是 把 一 定 的 数值 加 载 给 特定 的 变量 。 
赋值 运算 符 的 具体 含义 如 表 3-2 所 示 。 
表 3-2 赋值 运算 符 

运算 符 名 称 
三 将 右边 的 值 赋值 给 左边 的 变量 
二 将 左边 的 值 加 上 右边 的 值 ， 赋 给 左边 的 变量 
= 将 左边 的 值 减 去 右边 的 值 ， 赋 给 左边 的 变量 
hs 将 左边 的 值 乘 以 右边 的 值 ， 赋 给 左边 的 变量 


三 将 左边 的 值 除 以 右边 的 值 ， 赋 给 左边 的 变量 
二 将 左边 的 字符 串 连接 到 右边 
%= 将 左边 的 值 对 右边 的 值 取 余数 ， 赋 给 左边 的 变量 


例如 ，$a-=Sb 等 价 于 $a=$a-Sb， 其 他 赋值 运算 符 与 之 类 似 。 从 表 3-2 可 以 看 出 ， 赋 值 运算 
符 可 以 使 程序 更 加 简练 ， 从 而 提高 执行 效率 。 


3.6.4 比较 运算 符 
比较 运算 符 用 来 比较 其 两 端 数值 的 大 小 。 比 较 运算 符 的 具体 含义 如 表 3-3 所 示 。 


表 3-3 比较 运算 符 
运算 符 名 称 
一 相等 
上 不 相等 
> 大 于 
< 小 于 
一 大 于 等 于 
= 小 于 等 于 
一 精确 等 于 (类 型 ) 
一 不 精确 等 于 


其 中 ，- 一 和 ! 一 需要 特别 注意 一 下 。S$b- 一 sc 表示 $b 和 $e 不 只 是 数值 上 相等 ， 而 且 两 者 
的 类 型 也 一 样 ，$b!==Sc 表示 $b 和 $c 有 可 能 是 数值 不 等 ， 也 可 能 是 类 型 不 同 。 
【 例 3.16】( 示 例文 件 ch033.16php) 


<HTML> 
<HEAD> 


<TITLE> 使 用 比较 运算 符 </TITLE> 
</HEAD> 
<BODY> 
<2PHP 
$value="15"; 
echo "\$value = \"$value\""; 
echo "<br>\$value==15: "7 


var dump ($value==15); // 结 果 为 :bool (true) 
echo "<br>\$value==true: "7 
var dump ($value==true); // 结 果 为 :bool (true) 
echo "<br>\$value!=null: "7 
var_dump ($value!=nul1); // 结 果 为 :bool (true) 
echo "<br>\$value==false: "7 
var_dump ($value==false); // 结 果 为 :bool (false) 
echo "<br>\$value 区 
var_dump ($value= // 结 果 为 :bool (false) 
echo "<br>\$value===true: "7 
var_dump ($value===true); // 结 果 为 :bool (true) 
echo "<br>(10/2.0 !== 5): "7 
var_dump (10/2.0 !==5); // 结 果 为 :bool (true) 
?> 
</BODY> 
<HTML> 


程序 运行 结果 如 图 3-16 所 示 。 


¢ rr 
| 文件 (F) 妨 辑 (Ej 王 看 (V) 。 收 蕊 实 (A) 工具 (T) 三 动 (H} 


Svalue = 15”15==15: 
boolean truc 
Svalue==ture: 

bonlean true 
Svalue!=null; 


boolean true 


Svalue==false: 


boolean folsc 
Svalue ==—= 15: 
boolean false 
Svalue===true: 
boolean false 
(10/2.0 !== 5): 


boolean true 


3-16 ”使 用 比较 运算 符 


® 
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案例 课堂 由"… 


3.6.5 ”逻辑 运算 符 


一 个 编程 语言 最 重要 的 功能 之 一 就 是 进行 远 辑 判断 和 运算 。 比 如 逻辑 和 、 逻 辑 或 、 轴 辑 
非 。 逻 辑 运算 符 的 含义 如 表 3-4 所 示 。 


表 3-4 ”逻辑 运算 符 
运算 符 名 称 
&&、AND 逻辑 和 
小 OR 逻辑 或 
!、 NOT 逻辑 非 
XOR 逻辑 异 或 


2.6.6” 按 位 运算 符 


按 位 运算 符 是 把 整数 以 “位 ”为 单位 进行 处 理 。 按 位 运算 符 的 含义 如 表 3-5 所 示 。 
表 3-5 ” 按 位 运算 符 


按 位 或 


3.6.7 ”否定 控制 运算 符 
否定 控制 运算 符 用 在 “操作 数 ” 之 前 ， 用 于 对 操作 数 真 假 的 判断 。 否 定 控制 运算 符 的 含 
义 如 表 3-6 所 示 。 
表 3-6 否定 控制 运算 符 


名 称 
逻辑 非 
按 位 非 


3.6.8 ”错误 控制 运算 符 


错误 控制 运算 符 是 用 “@” 来 表示 的 ， 在 一 个 操作 数 之 前 使 用 ， 该 运算 符 用 来 屏蔽 错误 
信息 的 生成 。 


| 


3.6.9 三 元 运算 符 
三 元 运算 符 是 作用 在 三 个 操作 数 之 间 的 。 这 样 的 运算 符 在 PHP 中 只 有 一 个 ， 即 “? :”。 
3.6.10 ”运算 符 的 优先 级 和 结合 规则 


运算 符 的 优先 级 和 结合 规则 其 实 与 正常 的 数学 运算 符 的 规则 十 分 相似 : 

e ”加 减 乘除 的 先后 顺序 与 数学 运算 中 的 完全 一 致 。 

® ”对 于 括号 ， 则 先 运行 括号 内 ， 再 运行 括号 外 。 

e@ ”对 于 赋值 ， 则 由 右 向 左 运行 ， 也 就 是 依次 从 右边 向 左边 的 变量 进行 赋值 。 


廊 悄 计 和 ? 中 dHd 翰 8 洲 | 


3.7 ”PHP 中 的 表达 式 


表达 式 是 表达 一 个 特定 操作 或 动作 的 语句 。 表 达 式 由 “操作 数 ” 和 “操作 符 ” 组 成 。 
操作 数 可 以 是 变量 ， 也 可 以 是 常量 。 

操作 符 则 体现 了 要 表达 的 各 个 行为 ， 如 逻辑 判断 、 赋 值 、 运 算 等 。 

例如 $a=5 就 是 表达 式 ， 而 $a=5; 则 为 语句 。 另 外 ， 表 达 式 也 有 值 ， 例 如 表达 式 $a=1 的 值 


py A 


在 PHP 代码 中 ， 使 用 “;” 号 来 区 分 表达 式 和 语句 ， 即 一 个 表达 式 和 一 个 分 号 组 
成 一 条 PHP 语句 。 在 编写 代码 程序 时 ， 应 该 特别 注意 表达 式 后 面 的 “;”， 不 要 漏 写 
或 写 错 ， 否 则 会 提示 语法 错误 。 


3.8 创建 多 维 数组 


前 面 讲 述 了 如 何 创建 一 维 数组 ， 本 节 讲 述 如 何 创造 多 维 数组 。 多 维 数组 的 和 一 维 数组 的 
区 别 是 有 两 个 或 多 个 下 标 ， 它 们 的 用 法 基本 相似 。 

下 面 给 出 创建 二 维 数组 的 例子 。 

【 例 3.17】( 示 例文 件 ch033.17.php) 


<HTML> 
<HEAD> 
<TITLE> 二 维 数组 </TITLE> 
</HEAD> 
<BODY> 
<?php 
$arr[0] [0] 
$arr[0] [1] 
$arr[1] [0] 
$arr[1] [1] 


可 0 
2 

1E+05; 

"开始 学 习 PHP 基本 语法 了 "; 
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for ($i=0; $i<count ($arr); $i++) 
for ($k=0; $k<count ($arr[$i]); $k++) 
{ 
$arrl = each ($arr[$i]); 
echo "$arrl[value]<br>"; 


让 
?> 
</BODY> 
<HTML> 


程序 运行 结果 如 图 3-17 所 示 。 


人 Gleno- Box EE 


文件 (Fi) ”编辑 (E) 。 坦 看 (V) ”收藏 夫 (A) 工具 (T) ”帮助 (H) 


10 
22 
100000 


开始 学 习 PHP 基 本 语法 了 


图 3-17 创建 二 维 数组 


3.9 疑难 解 惑 
疑问 1: 如 何 灵活 运用 命名 空间 (namespace)? 


命名 空间 mamespaces) 作 为 一 个 比较 宽泛 的 概念 ， 可 以 理解 为 用 来 封装 各 个 项 目的 手段 。 
比如 文件 系统 中 不 同文 件 夹 路 径 中 的 两 个 文件 的 文件 名 可 以 完全 相同 ， 但 由 于 是 在 不 同 的 文 
件 夹 中 ， 所 以 是 两 个 完全 不 同 的 文件 。 

PHP 的 命名 空间 也 是 这 样 的 一 个 概念 。 它 主要 用 于 在 “类 的 命名 ”、“ 函 数 命名 ”及 
“常量 命名 ”中 避免 代码 冲突 和 在 命名 空间 下 管理 变量 名 和 常量 名 。 

命名 空间 使 用 namespace 关键 字 在 文件 头 部 定义 。 例 如 : 

<?php 

namespace 2ndbuilding\number24; 

class room{} 


$room = new _ NAMESPACE .room; 
> 


命名 空间 还 可 以 拥有 子 空间 ， 它 们 组 合 起 来 ， 就 像 文 件 夹 的 路 径 一 样 。 对 于 命名 空间 的 


使 用 ， 可 以 通过 内 置 变 量 NAMESPACE 来 使 用 命名 空间 及 其 子 空间 。 
疑问 2: 如 何 快速 区 分 常量 和 变量 ? 
常量 和 变量 的 明显 区 别 如 下 : 


常量 前 面 没有 美元 符号 ($)。 
常量 只 能 用 define0 函 数 定义 ， 而 不 能 通过 赋值 语句 定义 。 


常量 可 以 不 用 理会 变量 范围 的 规则 ， 可 以 在 任何 地 方 定义 和 访问 。 


常量 一 旦 定义 就 不 能 被 重新 定义 或 者 取消 定义 。 
常量 的 值 只 能 是 标量 。 


编程 语言 都 是 由 各 种 程序 结构 组 成 的 ， 常 见 的 有 顺序 结构 、 分 支 结构 和 循环 结 
构 。 在 学 习 程序 结构 前 ， 读 者 还 需要 对 函数 的 知识 进行 学 习 。 本 章 主 要 介绍 PHP 
语言 中 的 函数 及 语言 结构 的 使 用 方法 和 技巧 。 
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4.1 函 数 


函数 的 英文 为 function， 这 个 词 也 是 功能 的 意思 。 顾 名 思 义 ， 使 用 函数 就 是 要 在 编程 过 程 
中 实现 一 定 的 功能 ， 也 就 是 通过 一 段 代码 块 来 实现 一 定 的 功能 。 比 如 通过 一 定 的 功能 记录 下 
酒店 客人 的 个 人 信息 ， 每 到 他 生日 的 时 候 自动 给 他 发 送 祝贺 E-mail， 并 且 这 个 发 信 “ 功 能 ” 
可 以 重用 ， 将 来 在 某 个 客户 的 结婚 纪念 日 也 使 用 这 个 功能 给 他 发 送 祝福 E-mail。 可 见 ， 函 数 
就 是 实现 一 定 功能 的 一 段 特 定 的 代码 。 


4.1.1 认识 PHP 函数 


实际 上 ， 前 面 我 们 早已 使 用 过 函数 了 。 例 如 用 define0 函 数 定义 一 个 常量 。 如 果 现 在 再 写 
一 个 程序 ， 则 同样 可 以 调用 define() 函 数 。 
在 更 多 的 情况 下 ， 程 序 员 面 对 的 是 自 定义 函数 。 其 结构 如 下 : 


function name of function(paraml, param2, ...){ 
statement; 


} 


其 中 ，name_of function 是 函数 名 ，paraml、param2 是 参数 ， 而 statement 是 函数 的 具体 
内 容 。 


4.1.2 定义 和 调用 函数 


下 面 以 自 定义 和 调用 函数 为 例 进行 讲解 。 本 例 主要 实现 酒店 欢迎 页 面 。 
【 例 4.1】( 示 例文 件 ch04\4.1.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
function sayhello($customer){ 
return $customer."， 欢 迎 您 来 到 GoodHome 酒店 。"; 
; 
echo sayhello(' 张 先生 ' ); 
?> 
</BODY> 
</HTML> 


程序 运行 结果 如 图 4-1 所 示 。 


重 


于 久 htp://localhost P - BO X||@ localhost 


文件 (F) ”编辑 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 
张 先 生 ， 欢 迎 您 来 到 GoodHome 酒 店 。 


普 加 叫 琐 否 dHd_ 者 y 小 曾 国 


4-1 定义 和 调用 函数 


案例 分 析 : 
值得 一 提 的 是 ， 此 函数 是 以 值 的 形式 返回 的 。 也 就 是 说 return 语句 返回 值 时 ， 创 建 了 一 
个 值 的 拷贝 ， 并 把 它 返 回 给 使 用 此 函数 的 命令 或 函数 ， 在 这 里 是 echo 命令 。 


4.1.3 向 函数 传递 参数 值 


由 于 函数 是 一 段 封闭 的 程序 ， 很 多 时 候 ， 程 序 员 都 需要 向 函数 内 传递 一 些 数据 ， 来 进行 
操作 。 
可 以 接受 传 入 参数 的 函数 定义 形式 如 下 : 


function 函数 名 称 (参数 1， 参 数 2) { 
算法 描述 ， 其 中 使 用 参数 1 和 参数 2; 


多 A 


下 面 以 酒店 房间 住宿 费 总 价 为 例 进行 讲解 。 
【 例 4.2】( 示 例文 件 ch04\4.2.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

</HEAD> 

<BODY> 

<?php 

function totalneedtopay ($days, $roomprice){ 
$totalcost = $days*$roomprice; 
"需要 支付 的 总 价 : $totalcost"." 元 。"; 

a 

Srentdays = 3; 

$roomprice = 168; 

totalneedtopay ($rentdays, $roomprice); 

totalneedtopay (5,198); 

人 


</BODY> 
</HTML> 
运行 结果 如 图 4-2 所 示 。 
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【< 疝 名 hapyiocalhos DP BC X | @ localhost x 


文件 (月 ” 编 名 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


需要 支付 的 总 价 : 504 元 。 需 要 支付 的 总 价 : 990 元 。 


4-2 向 函数 传递 参数 值 


案例 分 析 : 

(1) 以 这 种 方式 传递 参数 值 的 方法 就 是 向 函数 传递 参数 值 。 

(2) 其 中 function totalneedtopay($days,$roomprice) 们 定义 了 函数 和 参数 。 

(3) 不 管 是 通过 变量 $rentdays 和 $roomprice 向 函数 内 传递 参数 值 ， 还 是 像 totalneedtopay 
(5,198) 这 样 直 接 传递 参数 值 ， 效 果 都 是 一 样 的 。 


4.1.4 向 函数 传递 参数 引用 


向 函数 传递 参数 引用 ， 其 实 就 是 向 函数 传递 变量 引用 。 参 数 引用 一 定 是 变量 引用 ， 静 态 
数值 是 没有 引用 一 说 的 。 变 量 引用 其 实 就 是 对 变量 名 的 使 用 ， 即 是 对 变量 位 置 的 使 用 。 

下 面 仍然 以 酒店 服务 费 总 价 为 例 进 行 讲解 。 

【 例 4.3】( 示 例文 件 ch04\4.3.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

</HEAD> 

<BODY> 

<?php 

$fee = 300; 

$serviceprice = 50; 

function totalfee(&$fee, $serviceprice){ 
$fee = $fee + $serviceprice; 
echo "需要 支付 的 总 价 : $fee" ." 元 。"; 

3 

totalfee ($fee, $serviceprice); 

totalfee ($fee, $serviceprice); 

?> 


</BODY> 
</HTML> 
运行 结果 如 图 4-3 所 示 。 


[< Er localhost x 同 | 攻 症 到 


文件 (月 ” 编 加 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


需要 支付 的 总 价 :350 元 。 需 要 支付 的 总 价 :400 元 。 


4-3 向 函数 传递 参数 引用 


案例 分 析 : 

(1) 以 这 种 方式 传递 参数 值 的 方法 就 是 向 函数 传递 参数 引用 。 使 用 “&” 符 号 表示 参数 
引用 。 

(2) 其 中 function totalfee(&$fee, $serviceprice){} 定 义 了 函数 、 参 数 和 参数 引用 。 变 量 $fee 
是 以 参数 引用 的 方式 进入 函数 的 。 当 函数 的 运行 结果 改变 了 变量 $fee 的 引用 的 时 候 ， 在 函数 
外 的 变量 $fee 的 值 也 发 生 了 改变 。 也 就 是 函数 改变 了 外 部 变量 的 值 。 


4.1.5 ”从 函数 中 返回 值 


以 上 的 一 些 例子 中 ， 都 是 把 函数 运算 完成 的 值 直接 打印 出 来 。 但 是 ， 很 多 情况 下 ， 程 序 
并 不 需要 直接 把 结果 打印 出 来 ， 而 是 仅仅 给 出 结果 ， 并 且 把 结果 传递 给 调用 这 个 函数 的 程 
序 ， 为 其 所 用 。 

这 里 需要 用 到 return 关键 字 。 下 面 以 酒店 客房 费用 为 例 进行 讲解 。 

【 例 4.4】( 示 例文 件 ch04\4.4.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

</HEAD> 

<BODY> 

<?php 

function totalneedtopay ($days, $roomprice){ 
return $days*$roomprice; 

3 

Srentdays = 3; 

Sroomprice = 168; 

echo totalneedtopay ($rentdays, $roomprice); 


?> 

</BODY> 

</HTML> 

运行 结果 如 图 4-4 所 示 。 


普 跑 串 琐 下 dHd_ 翰 了 名 品 


多 A 
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(< 部 名 htpy/localhos 只 - BCX localhost 


文件 (F) ” 编 罚 (E) ”查看 (V) 收藏 夫 (A) ”工具 (] 帮助 (H) 


4-4 从 函数 中 返回 值 


案例 分 析 : 

(1) 在 函数 function totalneedtopay($days,$roomprice) 的 算法 中 ， 直 接 使 用 retum 把 运算 的 
值 返 回 给 调用 此 函数 的 程序 。 

(2) 其 中 echo totalneedtopay($rentdays,$roomprice): 语 句 调用 了 此 函数 ，totalneedtopay0 把 
运算 结果 值 返回 给 了 echo 语句 。 才 有 上 面 的 显示 。 当 然 ， 这 里 也 可 以 不 用 echo 来 处 理 返回 
值 ， 也 可 以 对 它 进行 其 他 处 理 ， 比 如 赋值 给 变量 等 。 


4.1.6 引用 函数 


不 管 是 PHP 中 的 内 置 函数 ， 还 是 程序 员 在 程序 中 的 自 定义 函数 ， 都 可 以 直接 简单 地 通过 
函数 名 调用 。 但 是 在 操作 过 程 中 也 有 些 不 同 ， 大 致 分 为 以 下 3 种 情况 : 

e@ ”如 果 是 PHP 的 内 置 函数 ， 如 date0， 可 以 直接 调用 。 

@ ”如 果 这 个 函数 是 PHP 的 某 个 库 文件 中 的 函数 ， 则 需要 用 include0 或 require0) 命 令 把 
此 库 文 件 加 载 ， 然 后 才能 使 用 。 

@ ”如 果 是 自 定义 函数 ， 若 与 引用 程序 在 同一 个 文件 中 ， 则 可 直接 引用 ， 若 此 函数 不 在 
当前 文件 内 ， 则 需要 用 include0 或 require0 命 令 加 载 。 

对 函数 的 引用 ， 实 质 上 是 对 函数 返回 值 的 引用 。 

【 例 4.5】( 示 例文 件 ch044.5.php) 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title> 对 函数 的 引用 </title> 

</head> 

<body> 

<?php 

function &example ($aa=1){ // 定 义 一 个 函数 ， 别 忘 了 加 “s” 符 
return $aa; // 返 回 参 数 $str 

$bp = &example ("引用 函数 的 实例 ") ; // 声 明 一 个 函数 的 引用 $str1; 

echo $bb."<p>"; 

> 

</body> 

</html> 


运行 结果 如 图 4-5 所 示 。 
(¢SE htpylocalhost D BO X| @ xraysI 
文件 (月 ” 编 沾 (二 者 (V) “ 收 茂 夫 (A) 工具 (T) 者 动 () 
引用 函数 的 实例 i 
殷 100% ~ 
图 4-5 引用 函数 


案例 分 析 : 


(1) 本 例 首先 定义 一 个 函数 ， 然 后 变量 Sbb 将 引用 函数 ， 最 后 输出 变量 Sbb， 实 质 上 是 $aa 


的 值 。 


(2) 与 参数 传递 不 同 ， 使 用 函数 引用 时 ， 定 义 函 数 和 引用 函数 都 必须 使 用 “&” 符 ， 表 


明 返 回 的 是 一 个 引用 。 
4.1.7 取消 函数 引用 


对 于 不 需要 引用 的 函数 ， 可 以 做 取消 操作 。 取 消 引 用 函数 使 用 unset() 函 数 来 完成 ， 目 的 
是 断 开 变量 名 和 变量 内 容 之 间 的 绑 定 ， 此 时 并 没有 销毁 变量 内 容 。 


【 例 4.6】( 示 例文 件 ch04\4.6.php) 


<html> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 


<title> 对 函数 取消 引用 </title> 

</head> 

<body> 

<?php 
$num = 166; 
$math = &$num; 
echo "\Smath is: 
unset ($math); 
echo "\Smath is: ".$math."<br>"; 
echo "\$num is: ".$num; 


".$math."<br>"; 


?2> 
</body> 
</html> 


运行 结果 如 图 4-6 所 示 。 


// 声 明 一 个 整 型 变量 

// 声 明 一 个 对 变量 Snum 的 引用 $math 
// 输 出 引用 $math 

// 取 消 引 用 $math 

// 再 次 输出 引用 

// 输 出 原 变量 
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@S 碟 http://localhost 人 D7 旦 0 X | 匈 对 函数 取消 引用 


文件 (F) ” 编 弓 (E) ” 坦 看 (V) 收藏 夫 (A) 工具 (T) ”帮助 (H) 


Smath is: 166 
Smath is: 
$num is: 166 


赎 100% ~ 


图 4-6 取消 函数 引用 


案例 分 析 : 
本 程序 首先 声明 一 个 变量 和 变量 的 引用 ， 输 出 引用 后 取消 引用 ， 再 次 调用 引用 和 原 变 
量 。 从 图 4-6 可 以 看 出 ， 取 消 引 用 后 ， 对 原 变量 没有 任何 影响 。 


4.2 ”流程 控制 概述 


流程 控制 ， 也 叫 控制 结构 ， 是 在 一 个 应 用 中 用 来 定义 执行 程序 流程 的 程序 。 它 决定 了 某 
个 程序 段 是 否 会 被 执行 和 执行 多 少 次 。 

PHP 中 的 控制 语句 分 为 3 类 : 顺序 控制 语句 、 条 件 控制 语句 和 循环 控制 语句 。 其 中 顺序 
控制 语句 是 从 上 到 下 依次 执行 的 ， 这 种 结构 没有 分 支 和 循环 ， 是 PHP 程序 中 最 简单 的 结构 ， 
本 书 不 再 讲述 。 下 面 主 要 讲述 条 件 控制 语句 和 循环 语句 。 


4.3 条 件 控制 结构 
条 件 控制 语句 中 包含 两 个 主要 的 语句 ， 一 个 是 让 语句 ， 一 个 是 switch 语句 。 
4.3.1 单一 条 件 分 支 结构 (if 语句 ) 


站 语句 是 最 为 常见 的 条 件 控制 语句 。 它 的 格式 为 : 
if (条 件 判断 语 句 ) { 
执行 语句 ; 
} 
这 种 形式 只 是 对 一 个 条 件 进行 判断 。 如 果 条 件 成 立 ， 则 执行 命令 语句 ， 否 则 不 执行 。 
直 语 句 的 控制 流程 如 图 4-7 所 示 。 


程序 块 


结束 


4-7 ”if 语 名 的 控制 流程 
【 例 4.7】( 示 例文 件 ch04\4.7.php) 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title>if 语句 的 使 用 </title> 

</head> 

<body> 

<?php 

$num = rand(1,100); // 使 用 rand () 函数 生成 一 个 随机 数 

if ($num $ 2 != 0){ // 判 断 变量 Snum 是 否 为 奇数 
echo "\$num = $num"; // 如 果 为 奇数 ， 输 出 表达 式 和 说 明文 字 
echo "<br>$num 是 奇数 。"; 

} 

入 

</body> 

</html> 


运行 后 刷新 页 面 ， 结 果 如 图 4-8 所 示 。 


NN 


图 4-8 使 用 if 语 句 
案例 分 析 ; 
(1) 此 案例 首先 使 用 rand0 函 数 随机 生成 一 个 整数 Ssum， 然 后 判断 这 个 随机 整数 是 不 是 


奇数 ， 如 果 是 ， 则 输出 上 述 结果 ， 如 果 不 是 ， 则 不 输出 任何 内 容 ， 所 以 如 果 页 面 内 容 显 示 为 
空 ， 则 刷新 页 面 即 可 。 
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(2) rand0 函 数 返回 随机 整数 。 语 法 格式 如 下 : 


rand (min,max) 


此 函数 主要 是 返回 min 和 max 之 间 的 一 个 随机 整数 。 如 果 没 有 提供 可 选 参数 min 和 
max，rand() 将 返回 0 到 RAND MAX 之 间 的 伪 随 机 整数 。 


4.3.2 双向 条 件 分 支 结构 (if...else 语句 ) 


如 果 是 非 此 即 彼 的 条 件 判断 ， 可 以 使 用 让 .else 语句 。 它 的 格式 为 : 


if (条 件 判断 语句 ) { 
执行 语句 Ri 
}else{ 


执行 语句 B; 


} 


这 种 结构 形式 首先 判断 条 件 是 否 为 真 ， 如 果 为 真 ， 则 执行 语句 A， 否 则 执行 语句 B。 
让 ...else 语句 的 控制 流程 如 图 4-9 所 示 。 


图 4-9 if..else 的 控制 流程 
【 例 4.8】( 示 例文 件 ch04\4.8.php) 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>if..else 语句 的 使 用 </title> 
</head> 
<body> 
<?php 
$d = date("D"); 
if ($d=="Fri") 
echo "今天 是 周 五 哦 !"; 
SES 
echo "可 惜 今天 不 是 周 五 !"; 
党 产 
</body> 
</html> 


运行 结果 如 图 4-10 所 示 。 


DO weeeror o- 0x] 


4-10 ”使 用 if...else 语句 


4.3.3 ”多 向 条 件 分 支 结 构 (elseif 语句 ) 


在 条 件 控制 结构 中 ， 有 时 会 出 现 多 于 两 种 的 选择 ， 此 时 可 以 使 用 elseif 语句 。 它 的 语法 格 
式 为 : 
if (条 件 判断 语句 ) { 
命令 执行 语句 ; 
lelseif (条 件 判 断 语句 ) { 
命令 执行 语句 ; 


} 
elsel 

命令 执行 语句 ; 
} 


elseif 语句 的 控制 流程 如 图 4-11 所 示 。 


4-11 elseif 语句 的 控制 流程 
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【 例 4.9】( 示 例文 件 ch04\4.9.php) 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>elseif 语句 的 使 用 </title> 
</head> 
<body> 
<?php 
$score = 857 // 设 置 成 绩 变量 $score 
if ($score >= 0 and $score <= 60){ / /判断 成 绩 变量 是 否 在 0~60 之 间 
echo "您 的 成 绩 为 差 " ; // 如 果 是 ， 说 明成 绩 为 差 
jelseif($score > 60 and $score <= 80){ // 否 则 判断 成 绩 变 量 是 否 在 61~80 之 间 
echo "您 的 成 绩 为 中 等 "; // 如 果 是 ， 说 明成 绩 为 中 等 
Jelse{ // 如 果 两 个 判断 都 是 false， 则 输出 默认 值 
echo "您 的 成 绩 为 优等 "; // 说 明成 绩 为 优等 


} 


人 > 
</body> 
</html> 


运行 结果 如 图 4-12 所 示 。 


【¢ 间 优 hapylocalhost 只 - 昌 纺 X | @ slseif 厅 名 的 使 用 


文件 (六 刚 (E) 。 坦 看 (V) 收藏 夫 (A) 工具 (T) ”帮助 (H) 


您 的 成 绩 为 优等 


图 4-12 使 用 elseif 语句 
4.3.4 ”多 向 条 件 分 支 结构 (switch 语句 ) 


switch 语句 的 结构 给 出 不 同情 况 下 可 能 执行 的 程序 块 ， 条 件 满足 哪个 程序 块 ， 就 执行 哪 
个 。 它 的 语法 格式 为 : 
switch (条 件 判断 语句 ) { 
case 判断 结果 为 a: 
执行 语句 1; 


break; 


case 判断 结果 为 b: 
执行 语句 2; 
break; 
a 
执行 语句 mn; 
加 
车“ 条件 判断 语句 ”的 结果 符合 哪个 可 能 的 “判断 结果 ”， 就 执行 其 对 应 的 “执行 语 
句 ”。 如 果 都 不 符合 ， 则 执行 default 对 应 的 默认 “执行 语句 n”。 
switch 语句 的 控制 流程 如 图 4-13 所 示 。 


图 4-13 switch 语句 的 控制 流程 
【 例 4.10】( 示 例文 件 ch044.10.php) 


<html> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>switch 语句 的 使 用 </title> 
</head> 
<body> 
<?php 
+ 
switch ($x) 
case 1: 
echo "数值 为 1"; 
break; 
case 2: 
echo "数值 为 2"; 
break; 
Case 3: 


os®@ 
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echo "数值 为 本 只 人 
break; 
case 4 
echo "数值 为 4"; 
break; 
case 5: 
echo "数值 为 5"; 
break; 
default: 
echo "数值 不 在 1~5 之 间 "; 
?> 
</body> 
</html> 


运行 结果 如 图 4-14 所 示 。 


[< 图 爸 htpylocalhos P - SOX|@ sw 


文件 篇 各 E) 坦 看 (V) 收藏 夹 A) 工具 素 ” 
数值 为 5 


图 4-14 使 用 switch 语句 


4.4 循环 控制 结构 


循环 控制 语句 中 主要 包括 3 个 语句 ， 即 while 循环 、do...while 循环 和 for 循环 。while 循 
环 在 代码 运行 的 开始 检查 条 件 的 真 假 ， 而 do...while 循环 则 是 在 代码 运行 的 末尾 检查 条 件 的 真 


假 ， 所 以 ，do...while 循环 至 少 要 运行 一 遍 。 


4.4.1 while 循环 语句 


while 循环 的 结构 为 : 
while (条 件 判断 语句 ) { 
执行 语句 ; 
} 
其 中 当 “ 条 件 判断 语句 ”为 true 时 ， 执 行 后 面 的 “执行 语句 ”， 然 后 返回 到 条 件 表达 式 
继续 进行 判断 ， 直 到 表达 式 的 值 为 假 ， 才 能 跳出 循环 ， 执 行 后 面 的 语句 。 
while 循环 语句 的 控制 流程 如 图 4-15 所 示 。 


图 4-15 ”while 语句 的 控制 流程 
【 例 4.11】( 示 例文 件 ch04\4.11.php) 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>while 语句 的 使 用 </title> 
</head> 
<body> 
<?php 
$num = 1; 
$str = "20 以 内 的 奇数 为 :"; 
while(Snum <=20){ 
if($num % 2!= 0){ 
$str .= $num." "™; 


} 
$numt++? 
和 
echo $str; 
名 > 
</body> 
</html> 


运行 结果 如 图 4-16 所 示 。 


a 


Qe weeton 2- Sox| Suicanmes «| 


20 以 内 的 奇数 为 , 1 3 5 7 9 11 13 15 17 19 


图 4-16 使 用 while 循环 语句 


案例 分 析 : 
本 例 主要 实现 20 以 内 的 奇数 输出 。 从 1~20 依次 判断 是 否 为 奇数 ， 如 果 是 ， 则 输出 ， 如 
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果 不 是 ， 则 继续 下 一 次 循环 。 
4.4.2 do...while 循环 语句 
do...while 循环 的 结构 为 : 


dolf{ 
执行 语句 ; 
}while (条 件 判断 语句 ) 
首先 执行 do 后 面 的 “执行 语句 ”， 其 中 的 变量 会 随 着 命令 的 执行 发 生变 化 。 当 此 变量 通 
过 while 后 的 “条 件 判断 语句 ”判断 为 false 时 ， 将 停止 循环 执行 “执行 语句 ”。 
do...while 循环 语句 的 控制 流程 如 图 4-17 所 示 。 


开始 


图 4-17 do...while 循环 语句 的 控制 流程 
【 例 4.12】( 示 例文 件 ch04\4.12.php) 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>while 语句 的 使 用 </title> 


</head> 
<body> 
<?php 
$aa = 07 // 声 明 一 个 整数 变量 $aa 
while($aa != 0){ // 使 用 while 循环 输出 
echo "不 会 被 执行 的 内 容 "; // 这 句 不 会 被 输出 
El // 使 用 do. . .while 循环 输出 
echo "被 执行 的 内 容 "; // 这 句 会 被 输出 
}while(S$aa != 0); 
| 
</body> 
</html> 


运行 结果 如 图 4-18 所 示 。 从 结果 可 以 看 出 ，while 语句 和 do...while 有 很 大 的 区 别 。 


ce- |3 


DB epocalhost p - Sox] Gwei 


4-18 使 用 do...while 语句 
4.4.3 for 循环 语句 
for 循环 的 结构 如 下 : 


for (exprl; expr2; expr3) 
{ 

命令 语句 ; 
} 


其 中 exprl 为 条 件 的 初始 值 ，expr2 为 判断 的 最 终 值 ， 通 常 都 是 用 比较 表达 式 或 逻辑 表达 


式 充当 判断 的 条 件 ， 执 行 完 命令 语句 后 ， 再 执行 expr3。 
for 循环 语句 的 控制 流程 如 图 4-19 所 示 。 


exprl 


T 
程序 块 


erpr3 


4-19 “for 循环 语句 的 控制 流程 
【 例 4.13】( 示 例文 件 ch04\4.13.php) 


<HTML> 
<HEAD> 


of@ 
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案例 课堂 >… 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 


for($i=0; $i<4; $i++){ 
echo "for 语句 的 功能 非常 强大 <br>"; 


运行 结果 如 图 4-20 所 示 。 从 中 可 以 看 出 ， 语 句 执行 了 4 次。 


大 htpy/localhost PD ~ BCX| Elocalhost 
文件 (前 ” 妨 强 (E) ”查看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


for 语句 的 功能 非常 强大 


for 语句 的 功能 非常 强大 
for 语句 的 功能 非常 强大 
for 语句 的 功能 非常 强大 


图 4-20 使 用 for 循环 语句 
4.4.4 foreach 循环 语句 


foreach 语句 是 十 分 常用 的 一 种 循环 语句 ， 它 经 常 被 用 来 遍历 数组 元 素 ， 格 式 为 : 


foreach (数组 as 数组 元 素 ) { 
对 数组 元 素 的 操作 命令 ; 
可 以 把 数组 分 为 两 种 情况 ， 即 不 包含 键 值 的 数组 和 包含 键 值 的 数组 。 
(1) 不 包含 键 值 的 数组 : 
foreach (数组 as 数组 元 素 值 ) { 


对 数组 元 素 的 操作 命令 ; 
» 


(2) 包含 键 值 的 数组 : 


foreach (数组 as 键 值 => 数组 元 素 值 ) { 
对 数组 元 素 的 操作 命令 ; 
} 
每 进行 一 次 循环 ， 当 前 数组 元 素 的 值 就 会 被 赋值 给 数组 元 素 值 变量 ， 数 组 指针 会 逐一 地 
移动 ， 直 到 遍历 结束 为 止 。 
【 例 4.14】( 示 例文 件 ch04\4.14.php) 


<html> 
<body> 


全 7n 


全 中 

生 国 
<?php be 
be 
$arr = array ("one", "two", "three"); S| 
foreach ($arr as $value) 
{ 司 
echo "数组 值 : " . $value . "<br />"; 的 
) 语 
和 
绩 
</body> 构 

</html> 


运行 结果 如 图 4-21 所 示 。 从 中 可 以 看 出 ， 语 句 执行 了 3 次 。 


-oe 


OS 全 hapyWlocahos P ~ BO x | localt 
文件 (月 。 骗 句 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) 孝 8 ” 
数组 信 : one T 
数组 值 : two 

数组 值 : three 


4-21 使 用 foreach 循环 语句 


4.4.5 流程 控制 的 另 一 种 书写 格式 


在 一 个 含有 多 条 件 、 多 循环 的 语句 中 ， 包 含 多 个 入， 查看 起 来 比较 繁琐 。 流 程控 制 语句 
的 另外 一 种 书写 方式 是 以 “:” 来 代替 左边 的 大 括号 ， 使 用 endif、endwhile、endfor、endreach 
和 endswitch 来 替代 右边 的 大 括号 ， 这 种 描述 程序 结构 的 可 读 性 比较 强 。 
例如 常见 的 格式 如 下 。 
(1) 让 语句 : 
if (条 件 判断 语句 ) : 
执行 语句 1; 
elseif (条 件 判 断 语句 ) : 
执行 语句 2; 
elseif (条 件 判 断 语句 ) : 
执行 语句 3; 


py A 


else: 
执行 语句 n; 
endif; 


(2) switch 语句 : 


switch (条 件 判断 语句 ) : 
Case 判断 结果 a: 
执行 语句 1; 
case 判断 结果 b: 
执行 语句 2; 
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人 
执行 语句 n7 


endswitch; 


(3) while 循环 : 


while (条 件 判断 语句 ) : 
执行 语句 ; 


endwhile; 


(4) do...while 循环 : 


do 
命令 执行 语句 ; 
while (条 件 判 断 语 句 ) ; 


(5) for 循环 : 


for (初始 化 语句 ; 条件 终 止 语句 ; 增幅 语句 ) : 
执行 语句 ; 


endfor; 


【 例 4.15】( 示 例文 件 ch04\4.15.php) 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 杨 辉 三 角 </title> 
</head> 
<body> 
<?php 
Smixnum = 17 
Smaxnum = 10; 
$tmparr[][] = array(); 
$tmparr[0] [0] = 1; 
for($i = 1; $i < $maxnum; $i++): 
Eor(s = 0 9 < 
if($j == 0 or $j == $i): 
$tmparr[$i] [$j] = 1; 
else: 
$tmparr[$i] [$j] = $tmparr[$i - 1] [$j - 1] + $tmparr[$i - 1] [$j]; 
endif; 
endfor; 
endfor; 
foreach($tmparr as $value): 
foreach ($value as $v1) 
echo S$vl- "? 
echo '<p>'; 
endforeach; 


a 
</body> 
</html> 
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运行 结果 如 图 4-22 所 示 。 从 中 可 以 看 出 ， 该 代码 使 用 新 的 书写 格式 实现 了 杨辉 三 角 的 排 
列 输出 。 


【< OE | 
文件 (六 和 昌 。 评 帮 WV) 收 基 夫 A) 工具 才 动 H) 


1615201561 
172135352171 


18285670562881 


193684126126843691 


图 4-22 使 用 流程 控制 的 另 一 种 书写 格式 
4.4.6 ”使 用 break/continue 语句 跳出 循环 


break 关键 字 用 来 跳出 (也 就 是 终止 ) 循 环 控制 语句 和 条 件 控制 语句 中 的 switch 控制 语句 的 
执行 。 例 如 : 
<?php 
Sn = 0; 
while (++$n) { 
switch ($n) { 


NN 


case 1: 
echo "case one"; 
break; 

case 2: 
echo "case two"; 
break 2; 

default: 
echo ”Case three” 2 
break 1; 


} 

?> 

在 这 段 程序 中 ，while 循环 控制 语句 里 面包 含 一 个 switch 流程 控制 语句 。 在 程序 执行 到 
break 语句 时 ，break 会 终止 执行 switch 语句 ， 或 者 是 终止 执 行 switch 和 while 语句 。 其 中 ， 


pn 多 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 >… 


case 1 下 的 break 语句 跳出 了 switch 语句 。case 2 下 的 break 2 语句 跳出 switch 语句 和 包含 
switch 的 while 语句 。case 3 下 的 break 1 语句 与 case 1 下 的 break 语句 一 样 ， 只 是 跳出 switch 
语句 。 这 里 ，break 后 所 携带 的 数字 参数 是 指 break 要 跳出 的 控制 语句 结构 的 层 数 。 

使 用 continue 关键 字 的 作用 是 ， 跳 开 当 前 的 循环 友 代 项 ， 直 接 进入 到 下 一 个 循环 迭代 
继续 执行 程序 。 下 面 通 过 一 个 示例 来 说 明 此 关键 字 的 作用 。 

【 例 4.16】( 示 例文 件 ch044.16.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
Sn = 07 
while (Sn++ < 6) { 
1£ {Sn == 2)4 
continue; 


项 


echo $n."<br />"; 
} 


3 


</BODY> 
</HTML> 


运行 结果 如 图 4-23 所 示 。 


图 4-23 ”使 用 continue 关键 字 


案例 分 析 : 

continue 关键 字 在 n 等 于 2 的 时 候 跳 离 本 次 循环 ， 并 且 直 接 进入 到 下 一 个 循环 欠 代 项 ， 即 
当 n 等 于 3。 另 外 ，continue 关键 字 和 break 关键 字 一 样 ， 都 可 以 在 后 面 直接 跟 一 个 数字 参 
数 ， 用 来 表示 跳 开 循环 的 结构 层 数 。continue 与 continue 1 相同 。continue 2 表示 跳 离 所 在 循 
环 和 上 一 级 循环 的 当前 迭代 项 。 
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加 


4.5 综合 应 用 条 件 分 支 结构 


下 面 的 例子 讲述 条 件 分 支 结构 的 综合 应 用 。 
【 例 4.17】( 示 例文 件 ch04\4.17.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
$members = Null; 
function checkmembers ($members){ 
if ($members < 1){ 
echo "我 们 不 能 为 少 于 一 人 的 顾客 提供 房间 。<br />"; 
}elsef{ 
echo "欢迎 来 到 GoodHome 酒店 。<br />"; 


营 藤 趾 斑 踢 dHd_ 翰 了 对 图 | 


} 
3 
checkmembers (2); 
checkmembers (0.5); 
function checkmembersforroom($members){ 
if ($members < 1)1{ 
echo "我 们 不 能 为 少 于 一 人 的 顾客 提供 房间 。<br />"; 


多 A 


}elseif( $members == 1 ){ 

echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 单 床 房 。<br />"; 
}elseif( $members == 2 ){ 

echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 标准 间 。<br />"; 
}elseif( $members == 3 ){ 

echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 三 床 房 。<br />"; 
}elsef{ 


echo "请 直接 电话 联系 我 们 ， 我 们 将 依照 具体 情况 为 您 准备 合适 的 房间 。<br />"; 
} 
checkmembersforroom(1); 
checkmembersforroom(2); 
checkmembersforroom(3); 
checkmembersforroom(5); 
function switchrooms ($members){ 
Switch ($members){ 
case 1: 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 单 床 房 。<br />"; 
break; 
Case 2. 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 标准 间 。<br />"; 
break; 
case 32 
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echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 三 床 房 。<br />"; 
break; 
default: 
echo "请 直接 电话 联系 我 们 ， 我 们 将 依照 具体 情况 为 您 准备 合适 的 房间 。"; 
break; 
1 

Switchrooms (1); 

Switchrooms (2) 7 

Switchrooms (3) 7 

Switchrooms (5) 7 


运行 结果 如 图 4-24 所 示 。 


| 【< Er 县 ahos x ox 
文件 (有 ”篇 成 日 ”查看 V) 收 写 交 从 工具 () 地 吊 (H) 


欢迎 来 到 GoodHcme 酒 店 - | 
我 们 不 能 为 少 于 一 人 的 顾客 提供 房间 

欢迎 来 到 GoodHome 活 店 。 我 们 将 为 您 准备 单 床 房 。 

欢迎 来 到 GoodHome 活 店 。 我 们 将 为 您 准 各 标准 间 。 

欢迎 来 到 GoodHome 酒 店 。 我 们 将 为 您 准备 三 床 房 。 

请 直接 电话 联系 我 们 ， 我 们 将 依照 具体 情况 为 您 准备 合适 的 房间 

欢迎 来 到 GoodHome 酒 店 。 我 们 将 为 您 准备 单 床 房 。 

欢迎 来 到 GoodHome 酒 店 。 我 们 将 为 您 准备 标准 间 。 

欢迎 来 到 GoodHome 酒 店 。 我 们 将 为 您 准备 三 床 房 。 

请 直接 电话 联系 我 们 ， 我 们 将 依照 具体 情况 为 您 准备 合适 的 房间 


图 4.24 “综合 应 用 条 件 分 支 结构 


案例 分 析 : 
其 中 最 后 4 行 由 switch 语句 实现 。 其 他 输出 均 由 站 语句 实现 。 


4.6 综合 应 用 循环 控制 结构 


下 面 以 遍历 已 订房 间 门牌 号 为 例 ， 介 绍 循环 控制 语句 应 用 技巧 。 
【 例 4.18】( 示 例文 件 ch04\4.18.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 

<BODY> 

<?php 

Sbookedrooms = array('102°','202','203','303','307°'); 

for ($i=0; $i<5; $++)1 


echo $bookedrooms[$i]."<br />"; 
1 
function checkbookedroom while($bookedrooms){ 
-ra 
while (isset($bookedrooms[$i])){ 
echo $i.":".$bookedrooms[$i]."<br />"; 
$i++? 
} 
3. 


checkbookedroom while($bookedrooms); 


$i = 0; 
do{ 
echo $i."-".$bookedrooms[$i]."<br />"; 
Si++7 
} while(Si < 2); 
2 
</BODY> 
</HTML> 
运行 结果 如 图 4-25 所 示 。 
| re/ocahon P- ac *| Socahorn 
文件 明生 器， 重 看 V】 多 富 关 A| 工具 [者 功 |H 
图 4-25 综合 应 用 循环 控制 结构 
案例 分 析 : 


其 中 ，102 到 307 由 for 循环 实现 。0:102 到 4:307 由 while 循环 实现 。0-102 和 1-202 由 
do...while 循环 实现 。for 循环 和 while 循环 都 完全 遍历 了 数组 Sbookedrooms， 而 do...while 循 
环 由 于 while($i < 2)， 所 以 do 后 面 的 命令 执行 了 两 次 。 


4.7 疑难 解 惑 


疑问 1: 如 何 合理 运用 include_once() 和 require_once()? 

inclnude0 和 require0 函 数 在 其 他 PHP 语句 执行 之 前 运行 ， 引 入 需要 的 语句 并 加 以 执行 。 但 
是 每 次 运行 包含 此 语句 的 PHP 文件 时 ，include0 和 require0 函 数 都 要 运行 一 次 。include0 和 
requireO) 函 数 如 果 在 先前 已 经 运行 过 ， 并 且 引 入 了 相同 的 文件 ， 则 系统 就 会 重复 引入 这 个 文 


型 


普 辟 串 稍 否 dHd_ 才 攻 波 名 


IGG 
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件 ， 从 而 产生 错误 。 而 include_once0 和 require_once0 函 数 只 是 在 此 次 运行 的 过 程 中 引入 特定 
的 文件 或 代码 ， 但 是 在 引入 之 前 ， 会 先 检查 所 需 文件 或 者 代码 是 否 已 经 引入 ， 如 果 已 经 引 
入 ， 将 不 再 重复 引入 ， 从 而 不 会 造成 冲突 。 


疑问 2: 程序 检查 后 正确 ， 却 显示 Notice: Undefined variable， 为 什么 ? 


PHP 默认 配置 会 报 这 个 错误 ， 就 是 将 警告 在 页 面 上 打印 出 来 ， 虽 然 这 有 利于 暴露 问题 ， 
但 实际 使 用 中 会 存在 很 多 问题 。 

通用 的 解决 办 法 是 修改 php.ini 的 配置 ， 需 要 修改 的 参数 如 下 : 

@ ”找到 error reporting =E_ALL， 修 改 为 error reporting=E ALL &~E NOTICE。 


@ ”找到 register globals = Off， 修 改 为 register globals = On。 


字符 串 在 PHP 程序 中 经 常 应 用 ， 如 何 格式 化 字符 串 、 连 接 /分 离 字 符 串 、 比 较 
字符 串 等 ， 是 初学 者 经 常 遇 到 的 问题 ， 本 章 将 介绍 这 些 知识 。 另 外 ， 本 章 还 将 讲述 
正则 表达 式 的 使 用 方法 和 技巧 。 
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5.1 字符 串 的 单 引 号 和 双 引 号 


字符 串 ， 是 指 一 连 串 不 中 断 的 字符 。 这 里 的 字符 主要 包括 以 下 几 种 类 型 。 

® ”字母 类 型 : 例如 常见 的 a、b、c 等 。 

e ”数字 类 型 :例如 常见 的 1、2、3、4 等 。 

。 ”特殊 字符 类 型 : 例如 常见 的 #、%、^、$ 等 。 

。 ”不 可 见 字符 类 型 : 例如 回 车 符 、Tab 字符 和 换行 符 等 。 

通常 使 用 单 引号 或 双 引号 来 标识 字符 串 ， 表 面 看 起 来 没有 什么 区 别 ， 但 是 ， 对 存在 于 字 
符 串 中 的 变量 来 说 ， 二 者 是 不 一 样 的 : 双 引 号 内 会 输出 变量 的 值 ， 而 单 引 号 内 则 直接 显示 变 
量 名 称 。 双 引号 中 可 以 通过 “\” 转 义 符 输 出 的 特殊 字符 如 表 5-1 所 示 。 


表 5-1 双 引 号 中 可 以 通过 “\” 转 义 符 输出 的 特殊 字符 


特殊 字符 含义 
mn 换行 且 回 到 下 一 行 的 最 前 端 
Tab 
\ 反 和 斜 杠 
‘0 ASCI 码 的 0 
\$ 把 此 符号 转 义 为 单纯 的 美元 符号 ， 而 不 再 作为 声明 变量 的 标识 符 
Yr 换行 

\{octal #} 八进制 转 义 

\x {hexadecimal #} 十 六 进 制 转 义 


而 单 引号 中 可 以 通过 “\” 转 义 符 输出 的 特殊 字符 只 有 如 表 5-2 所 示 的 两 个 。 
表 5-2 单 引号 中 可 以 通过 “\” 转 义 符 输出 的 特殊 字符 
含义 
转 义 为 单 引号 本 身 ， 而 不 作为 字符 串 标识 符 
反 和 斜 杠 转 义 为 其 本 身 
下 面 通过 示例 来 讲解 它们 的 不 同 用 法 。 
【 例 $.1】( 示 例文 件 ch05\5.1.php) 


<HTML> 
<HEAD> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 

<BODY> 

<?php 


@s 
第 图 
$message = "PHP 程序 "; oy 
echo "这 是 关于 字符 串 的 程序 。<br />"; | 
echo "这 是 一 个 关于 双 引 号 和 \$ 的 $message<br />"; 字 
$message2 = ' 字 符 串 的 程序 。'; 和 
echo ' 这 是 一 个 关于 字符 串 的 程序 。<br /> ，' 和 
echo ' 这 是 一 个 关于 单 引号 的 $message2'; 最 
echo $message2; 表 
?> 这 
</BODY> 
</HTML> 


运行 结果 如 图 5-1 所 示 。 可 见 单 引号 串 和 双 引 号 串 在 PHP 中 处 理 普 通 的 字符 串 时 效果 是 
一 样 的 ， 而 在 处 理 变量 时 是 不 一 样 的 ， 单 引号 串 中 的 内 容 只 是 被 当成 普通 的 字符 串 处 理 ， 而 
双 引 号 串 中 的 内 容 是 可 以 被 解释 并 蔡 换 的 。 


大 hapy/localhos DD- 昌 CX | 个 Iocalhost 
文件 (篇 回 (E) ”前 看 V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


这 是 关于 字符 串 的 

是 关 下定 起 遇 从 ;npr 可 

这 是 一 个 关于 字符 串 的 程序 。 

这 是 一 个 天 于 单 引号 的 $message2 字 符 串 的 程序 。 


py HH 


图 5-1 单 引号 和 双 引 号 的 区 别 


案例 分 析 : 

(1) 第 一 段 程 序 使 用 双 引 号 对 字符 串 进行 处 理 。\$ 转 义 成 了 美元 符号 。$message 的 值 
“PHP 程序 ”被 输出 。 

(2) 第 二 有 段 程序 使 用 单 引号 对 字符 串 进行 处 理 。$message2 的 值 在 单 引 号 的 字符 串 中 无 法 
被 输出 ， 但 是 可 以 通过 变量 打印 出 来 。 


5.2 字符 串 的 连接 符 


字符 串 连 接 符 的 使 用 十 分 频繁 。 这 个 连接 符 就 是 “.”( 点 )。 它 可 以 直接 连接 两 个 字符 
串 ， 可 以 连接 两 个 字符 串 变量 ， 也 可 以 连接 字符 串 和 字符 串 变量 。 

【 例 5.2】( 示 例文 件 ch05\5.2.php) 

<HTML> 


<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
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</HEAD> 

<BODY> 

<?php 
// 定 义 字符 串 
$a = "使 用 字符 串 的 连接 符 "，; 
$b = "可 以 非常 方面 地 连接 字符 串 "; 
// 连 接 上 面 两 个 字符 串 中 间 用 逗号 分 隔 
$c = $a."，".$b; ”// 输 出 连接 后 的 字符 串 
echo $c; 

人 

</BODY> 

</HTML> 


运行 结果 如 图 5-2 所 示 。 


[< 个 侣 http://localhost D7 BCX | localhost 


文件 (” 纺 名 (日 ”查看 (V) ， 收 鄞 夫 (A) “工具 (D 才 助 (H) 
使 用 字符 串 的 连接 符 ， 可 以 非常 方面 地 连接 字符 串 


5-2 ”使 用 字符 串 的 连接 符 


除了 上 面 的 方法 以 外 ， 读 者 还 可 以 使 用 了 f} 方 法 来 连接 字符 串 ， 此 方法 类 似 于 C 中 printf 
的 占 位 符 。 下 面 举 例 说 明 使 用 方法 。 
【 例 5.3】( 示 例文 件 ch05\5.3.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
// 定 义 需要 插入 的 字符 串 
$a = " 张 先生 "; 
// 生 成 新 的 字符 串 
$b = "欢迎 { $a} 入住 丰 乐 园 高 级 酒店 "; 
// 输 出 连接 后 的 字符 串 


echo $b; 


【< Er YEE 


文件 (有 ] ”编辑 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


是 号 

第 转 
> a 
</BODY> 司 | 
</HTML> Es 
运行 结果 如 图 5-3 所 示 。 划 
正 
则 
表 
达 
式 


欢迎 张 先 生 入 住 丰 乐 园 高 级 酒店 


戈 100% ~ 


图 5-3 使 用 人 方法 来 连接 字符 串 


5.3 字符 串 的 基本 操作 


字符 串 的 基本 操作 主要 包括 对 字符 串 的 格式 化 处 理 、 连 接 / 切 分 字符 串 、 比 较 字 符 串 、 字 
符 串 子 串 的 对 比 与 处 理 等 。 


5.3.1 手动 和 自动 转 义 字符 串 中 的 字符 


手动 转 义 字符 串 数据 ， 就 是 在 引号 内 (包括 单 引号 和 双 引 号 ) 通 过 使 用 “\” 反 和 斜 杠 使 一 些 
特殊 字符 转 义 为 普通 字符 。 这 个 方法 在 介绍 单 引 号 和 双 引 号 的 时 候 已 经 有 了 详细 的 描述 。 

自动 转 义 字符 串 的 字符 ， 是 通过 PHP 的 内 置 函 数 addslashes() 来 完成 的 。 还 原 这 个 操作 则 
是 通过 stripslashes() 来 完成 的 。 以 上 两 个 函数 也 经 常用 于 格式 化 字符 串 以 实现 MySQL 的 数据 
库 储存 。 


5.3.2 计算 字符 串 的 长 度 


计算 字符 串 的 长 度 在 很 多 应 用 中 都 经 常 出 现 ， 比 如 统计 输入 框 输入 文字 的 多 少 等 。 这 个 
功能 使 用 strlen0 函 数 就 可 以 实现 。 以 下 介绍 计算 字符 串 长 度 的 方法 和 技巧 。 
【 例 5.4】( 示 例文 件 ch05\5.4.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 

$someinput = "这 个 字符 串 的 长 度 不 长 。length is not long."; 


GG 
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$length = strlen($someinput); 
ifl(strlen($someinput)>50){ 

echo "输入 的 字符 串 的 长 度 不 能 大 于 50 个 字符 。"; 
lelse{ 

echo "允许 输入 字符 串 的 长 度 ， 此 字符 串 长 度 为 $length"; 
} 


二 


</BODY> 
</HTML> 
运行 结果 如 图 5-4 所 示 。 
[< 站 @ htpi//localhost P - BO X | @ localhost 一 
文件 (月 ”编辑 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 
允许 输入 字符 串 的 长 度 ， 此 字符 串 长 度 为 41 
图 5-4 使 用 strlen() 函 数 
案例 分 析 : 
(1) $someinput 为 一 个 字符 串 变量 。strlen($someinput) 则 是 直接 调用 strlen0) 函 数 计算 出 字 
符 串 的 长 度 。 


(2) 在 站 语 句 中 ，strlen($someinput) 返 回 字符 串 长 度 并 与 50 这 一 上 限 做 比较 。 

(3) $someinput 中 有 中 文 和 英文 两 种 字符 。 由 于 每 个 中 文字 占 两 个 字符 位 ， 而 每 个 英文 
字符 只 占 一 个 字符 位 ， 且 字符 串 内 的 每 个 空格 也 算 一 个 字符 位 ， 所 以 ， 最 后 字符 串 的 长 度 为 
41 个 字符 。 


5.3.3 字符 串 单词 统计 


有 的 时 候 ， 对 字符 串 的 单词 进行 统计 有 更 大 的 意义 。 使 用 str_word_countO 函 数 可 以 实现 
此 操作 ， 但 该 函数 只 对 基于 ASCII 码 的 英文 单词 起 作用 ， 并 不 对 UTFS 的 中 文字 符 起 作用 。 

下 面 通过 例子 介绍 字符 串 单词 统计 中 的 应 用 和 技巧 。 

【 例 5.5】( 示 例文 件 ch05\5.5.php) 

<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

</HEAD> 

<BODY> 

<?php 


$someinput = "How many words in this sentence? Just count it."; 
$someinput2 = "这 个 句子 由 多 少 个 汉字 组 成 ? 数 一 数 也 不 知道 。"; 
echo str word count ($someinput)."<br />"; 
echo str word count ($someinput2); 
?> 
</BODY> 
</HTML> 


运行 结果 如 图 5-5 所 示 。 可 见 str_word_countO 函 数 无 法 计算 中 文字 符 ， 查 询 结果 为 0。 


OS 纺 htpi//localhost PD ~ BO X||@localhost 


文件 ( ”编辑 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


ph pn 9 


9 
0 


护 100% ~ 


5-5 使 用 str_word_count() 函 数 


5.3.4 ”清理 字符 串 中 的 空格 


空格 在 很 多 情况 下 是 不 必要 的 。 所 以 清除 字符 串 中 的 空格 显得 十 分 重要 。 例 如 ， 在 判定 
输入 是 否 正确 的 程序 中 ， 出 现 了 不 必要 的 空格 ， 将 增 大 程序 出 现 错误 判断 的 几率 。 

清除 空格 要 使 用 到 ltrim(0、rtrim0 和 trim0) 函 数 。 

其 中 ，ltrim0 是 从 左面 清除 字符 串 头 部 的 空格 。rtrim0 是 从 右面 清除 字符 串 尾 部 的 空格 。 
trim() 则 是 从 字符 串 两 边 同时 去 除 头 部 和 尾部 的 空格 。 

以 下 例子 介绍 去 除 字 符 串 中 空格 的 方法 和 技巧 。 

【 例 5.6】( 示 例文 件 ch05\5.6.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

</HEAD> 

<BODY> 

<?php 
$someinput = " 这 个 字符 串 的 空格 有 待 处 理 。 "; 
echo "Output:" .Itrim(S$Ssomeinput) ."End <br />"; 
echo "Output:" .rtrim(Ssomeinput) ."End <br />"; 
echo "Output:" .trim(Ssomeinput) ."End <br />"; 
$someinput2 = "这 个 字符 串 的 空格 有 待 处 理 。 "; 
echo "Output :" .trim(S$Ssomeinput2) ."End"7 

有 二 

</BODY> 

</HTML> 
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运行 结果 如 图 5-6 所 示 。 


碟 http://localhost DD 旦 0 X | 刁 localhost 
文件 (月 ”编辑 (E) ”可 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


Output :这 个 字符 串 的 | 空格 有 待 处 理 。End 


戈 100% ~ 


5-6 ”清理 字符 串 中 的 空格 


案例 分 析 : 

(1) $someinput 为 一 个 两 端 都 有 空格 的 字符 串 变量 。ltrim($someinpub 从 左边 去 除 空格 ， 
rtrim($someinput) 从 右面 去 除 空格 ，trim($someinput) 从 两 边 同时 去 除 ， 得 到 这 些 输出 结果 。 

(2) $someinput2 为 一 个 两 端 都 有 空格 且 中 间 也 有 空格 的 字符 串 。 用 trim($someinput2) 处 
理 ， 还 只 是 去 除了 两 边 的 空格 。 


5.3.5 ”字符 串 的 切 分 与 组 合 


字符 串 的 切 分 使 用 explode0 和 strtok0 函 数 。 切 分 的 反 向 操作 为 组 合 ， 使 用 implode0 和 
join0 函 数 。 

其 中 ，explode0 把 字符 串 切 分 成 不 同 部 分 后 ， 存 入 一 个 数组 。impolde0 函 数 则 是 把 数组 
中 的 元 素 按照 一 定 的 间隔 标准 组 合成 一 个 字符 串 。 

以 下 示例 介绍 字符 串 切 分 和 组 合 的 方法 和 技巧 。 

【 例 5.7】( 示 例文 件 ch05\5.7.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
$someinput = "How to split this sentance."; 
$someinput2 = "把 这 个 句子 按 空格 拆 分 。"; 
$a = explode(' ',$someinput); 
print r($a); 
$b = explode(' ',$someinput2); 
print r($b); 
echo implode('>',$a)."<br />"; 
echo implode('*',$b); 
2> 
</BODY> 
</HTML> 


运行 结果 如 图 5-7 所 示 。 


[加 均 htpylocalhos D - BO X||@ localhost 


文件 (月 ” 编 铝 (E) 。 音 看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 


Array ( [0] => How [1] => to [2] => split 
[3] => this [4] => sentance. ) Array ( [0] 
=> 把 [1] => 这 个 句子 [2] => 按 空格 [3] => 


分 。 ) How>to>split>this>sentance. 


把 * 这 个 句子 + 按 空格 # 拆 分 。 


5-7 ”字符 串 的 切 分 与 组 合 


案例 分 析 : 

(1) explode0 函 数 把 $gsomeinput 和 $someinput2 按照 下 划 线 和 空格 的 位 置 分 别 切 分 成 $a 和 
$b 两 个 数组 。 

(2) implodeO 函 数 把 $Sa 和 $b 两 个 数组 的 元 素 分 别 按照 “>” 为 间隔 和 “*” 为 间隔 组 合成 
新 的 字符 串 。 


5.3.6 ”字符 串 子 串 的 截取 


在 一 串 字 符 串 中 截取 一 个 子 串 ， 就 是 字符 串 截取 。 

完成 这 个 操作 需要 用 到 substr0 函 数 。 这 个 函数 有 三 个 参数 。 分 别 规定 了 目标 字符 串 、 起 
始 位 置 和 截取 长 度 。 它 的 格式 如 下 : 

substr (目标 字符 串 ， 起 始 位 置 ， 截 取 长 度 ) 


其 中 目标 字符 串 是 某 个 字符 串 变 量 的 变量 名 ， 起 始 位 置 和 截取 长 度 都 是 整数 。 

如 果 都 是 正 数 ， 起 始 位 置 的 整数 必须 小 于 截取 长 度 的 整数 ， 和 否则 函数 返回 值 为 假 。 

如 果 截 取 长 度 为 负数 ， 则 意味 着 是 从 起 始 位 置 开 始 往 后 除去 从 目标 字符 串 结尾 算 起 的 长 
度数 的 字符 以 外 的 所 有 字符 。 

以 下 例子 介绍 字符 串 截取 的 方法 和 技巧 。 

【 例 5.8】( 示 例文 件 ch05\5.8.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
$someinput = "create a substring of this string."; 
$someinput2 = "创建 一 个 这 个 字符 串 的 子囊 。"; 
echo substr($someinput,0,11)."<br />"; 
echo substr($someinput,1,15)."<br />"; 
echo substr($someinput,0,-2)."<br />"; 


[| 
a 
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echo substr($someinput2,0,12)."<br />"; 
echo substr($someinput2,0,10)."<br />"; 
echo substr($someinput2,0,11); 

2 


</BODY> 
</HTML> 
运行 结果 如 图 5-8 所 示 。 
全 htpy/localhost PD ™ BCX | Elocalhost 
文件 (有 ) ”编辑 (E) ”查看 (V) 收藏 夫 (A) ”工具 (D) 帮助 (H) 
create a su 
reate a substri 
create a substring of this strin 
创建 一 个 这 
图 5-8 使 用 substr() 函 数 
案例 分 析 : 


(1) $someinput 为 英文 字符 串 变 量 。substr($someinput,0,11)、substr($someinput,1,15) 展 示 
了 起 始 位 和 截取 长 度 。 substr($someinput,0,-2) 则 是 从 字符 串 开头 算 起 ， 除了 最 后 两 个 字符 ， 其 
他 字符 都 截取 的 子 字符 串 。 

(2) $someinput2 为 中 文字 符 串 变量 。 因 为 中 文字 符 都 是 全 角 字 符 ， 都 占 两 个 字符 位 ， 所 
以 截取 长 度 一 定 要 是 偶数 ， 如 果 是 奇数 ， 则 在 此 字符 位 上 的 汉字 将 不 被 输出 。 


5.3.7 ”字符 串 子 串 的 替换 


在 某 个 字符 串 中 蔡 换 其 中 的 某 个 部 分 是 重要 的 应 用 ， 就 像 在 使 用 文本 编辑 器 中 的 替换 功 
能 一 样 。 

完成 这 个 操作 需要 使 用 substr replace0 函 数 。 它 的 格式 为 : 

substr_replace (目标 字符 串 ， 蔡 换 字 符 串 ， 起 始 位 置 ， 蔡 换 长 度 ) 


下 面 举例 介绍 字符 串 蔡 换 的 方法 和 技巧 。 
【 例 5.9】( 示 例文 件 ch05\5.9.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 

<BODY> 

<?php 


@s 
加 一 
$someinput = "ID:125846843388648"; on 
echo substr replace($someinput, ™***w 太 太太 太太 "m3;11) ."<br />"; 章 
echo substr replace($someinput, " 尾 号 为 " ,3,11); Ee 
2 和 
</BODY> 型 
</HTML> EE 
i < 
运行 结果 如 图 5-9 所 示 。 要 
世 式 
[¢ 回 贸 htpy/localhost PD ~ B © x | @ localhost 
文件 (月 ”编辑 (E) ”前 看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 
工 D :站 站 站 不 不 不 站 不 不 站 不 B648 
ID: 尾 号 为 8648 NN 
5-9 使 用 substr_replace() 函 数 
案例 分 析 : 
(1) $someinput 字符 串 变 量 从 第 3 个 字符 开始 为 ID 号 。 第 一 个 输出 是 以 “ 兴 下 洗 下 


替换 第 三 个 字符 开始 往 后 的 11 个 字符 。 
(2) 第 二 个 输出 是 用 “ 尾 号 为 "替代 第 3 个 字符 开始 往 后 的 11 个 字符 。 


5.3.8 字符 串 查找 


在 一 个 字符 串 中 查找 另外 一 个 字符 串 ， 就 像 文本 编辑 器 中 的 查找 一 样 。 实 现 这 个 操作 需 
要 使 用 strstr0) 或 stristr0 函 数 。strstr0 函 数 的 格式 为 : 
strstr (目标 字符 串 ， 需 查找 的 字符 串 ) 


当 函 数 找到 需要 查找 的 字符 或 字符 串 时 ， 则 返回 从 第 一 个 查找 到 字符 串 的 位 置 往 后 所 有 
的 字符 串 内 容 。 

stristr() 函 数 为 不 敏感 查找 ， 也 就 是 对 字符 的 大 小 写 不 敏感 。 用 法 与 strstr0 相 同 。 

下 面 介绍 字符 串 查找 的 方法 和 技巧 。 

【 例 5.10】( 示 例文 件 ch05\5.10.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
$someinput = "I have a Dream that to find a string with a dream."; 
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$someinput2 = "我 有 一 个 梦想 ， 能 够 找到 理想 。"; 
echo strstr($someinput,"dream")."<br />"; 
echo stristr($someinput,"dream")."<br />"; 
echo strstr($someinput,"that")."<br />"; 
echo strstr($someinput2, "梦想 ") ."<br />"; 

党 冯 : 

</BODY> 

</HTML> 


运行 结果 如 图 5-10 所 示 。 


全 htpy/localhos Dv CX| Elocalhost 
文件 (F) ”编辑 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 


dream. 
Dream that to find a string with a dream. 
that to find a string with a dream. 


梦想 ， 能 够 找到 理想 。 


图 5-10 使 用 字符 串 查找 


案例 分 析 : 

(1) $someinput 为 英文 字符 串 变 量 。strstr($someinput,“dream”) 对 大 小 写 敏感 ， 所 以 输出 
字符 串 中 最 后 的 字符 。stristr($someinput,“dream”*) 对 大 小 写 不 敏感 ， 所 以 直接 在 第 一 个 大 写 的 
匹配 字符 处 开始 输出 。 

(2) $someinput2 为 中 文字 符 串 变量 。strstr0 函 数 同样 对 中 文字 符 起 作用 。 


5.4 什么 是 正则 表达 式 


上 面 介 绍 的 对 字符 串 的 处 理 比 较 简单 ， 只 是 使 用 一 定 的 函数 对 字符 串 进行 处 理 ， 无 法 满 
足 对 字符 串 进 行 复杂 处 理 的 需求 ， 此 时 就 需要 使 用 正则 表达 式 。 

正则 表达 式 是 把 文本 或 字符 串 按照 一 定 的 规范 或 模型 表示 的 方法 。 经 常用 于 文本 的 匹配 
操作 。 

例如 ， 验 证 用 户 在 线 输入 的 邮件 地 址 的 格式 是 否 正 确 时 ， 常 常 使 用 正则 表达 式 技 术 来 匹 
配 ， 若 匹配 ， 则 用 户 所 填写 的 表单 信息 将 会 被 正常 处 理 ; 反 之， 如 果 用 户 输入 的 邮件 地 址 与 
正则 表达 的 模式 不 匹配 ， 将 会 弹出 提示 信息 ， 要 求 用 户 重新 输入 正确 的 邮件 地 址 。 可 见 正则 
表达 式 在 Web 应 用 的 逻辑 判断 中 具有 举足轻重 的 作用 。 


5.5 ”正则 表达 式 的 语法 规则 


一 般 情 况 下 ， 正 则 表达 式 由 两 部 分 组 成 ， 分 别 是 元 字符 和 文本 字符 。 元 字符 就 是 具有 特 
殊 含义 的 字符 ， 例 如 ?和 * 等 ， 文 本 字符 就 是 普通 的 文本 ， 例 如 字母 和 数字 等 。 本 章 主 要 讲述 
正则 表达 式 的 语法 规则 。 


5.5.1 方 括号 ([]) 


方 括号 内 的 一 串 字符 是 将 要 用 来 进行 匹配 的 字符 。 
例如 ， 正 则 表达 式 在 方 括 号 内 的 [name] 是 指 在 目标 字符 串 中 寻找 字母 n、a、m、e。[jk] 表 
示 在 目标 字符 串 中 寻找 字符 j 和。 


5.5.2 连 字 符 (-) 


很 多 情况 下 ， 不 可 能 逐个 列 出 所 有 的 字符 。 比 如 ， 若 需要 匹配 所 有 英文 字符 ， 则 把 26 个 
英文 字母 全 部 输入 ， 这 会 十 分 困难 。 这 样 ， 就 有 了 如 下 表示 。 

e@ [a-z]: 表示 匹配 英文 小 写 从 a 到 z 的 任意 字符 。 

e@ [A-Z]: 表示 匹配 英文 大 写 从 A 到 2Z 的 任意 字符 。 

e@ [A-Za-z]: 表示 匹配 英文 大 小 写 从 大 写 A 到 小 写 z 的 任意 字符 。 

e@ [0-9]: 表示 匹配 从 0 到 9 的 任意 十 进 制 数 。 

由 于 字母 和 数字 的 区 间 固 定 ， 所 以 根据 这 样 的 表示 方法 [开始 -结束 ]， 程 序 员 可 以 重新 定 
义 区 间 大 小 ， 如 [2-7]、[c-f 等 。 


5.5.3 点 号 字符 (.) 


点 号 字符 在 正则 表达 式 中 是 一 个 通配符 。 它 代表 所 有 字符 和 数字 。 例 如 ，“.er” 表 示 所 
有 以 er 结尾 的 三 个 字符 的 字符 串 ， 可 以 是 per、ser、ter、@er、&er 等 。 


5.5.4 限定 符 (+*?{n,m)) 


加 号 “+” 表 示 其 前 面 的 字符 至 少 有 一 个 。 例 如 “9+” 表 示 目 标 字符 串 包含 至 少 一 个 9。 

星 号 “* ”表示 其 前 面 的 字符 有 不 止 一 个 或 零 个。 例如 “y* ”表示 目标 字符 串 包 含 0 个 或 
者 不 止 一 个 y。 

问号 “?” 表 示 其 前 面 的 字符 有 一 个 或 零 个 。 例如“y?” 表 示 目 标 字符 串 包含 0 个 或 者 一 


个 y。 
大 括号 “ {n,m} ”表示 其 前 面 的 字符 有 n 或 m 个 。 例 如 “af3.5} ”表示 目标 字符 串 包 含 3 
个 或 者 5 个 a， 而 “a{3}” 表 示 目 标 字符 串 包含 3 个 a，“a{3,}” 表 示 目 标 字符 串 包含 至 少 3 


个 


二 


此 评 淋 昱 月 过 开导 M 坤 9 小 | 


IGG 
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点 号 和 星 号 一 起 使 用 ， 表 示 广 义 同 配 。 即 “.*” 表 示 匹 配 任意 字符 。 


5.5.5 行 定 位 符 (^ 人 和 9) 


行 定 位 符 用 来 确定 匹配 字符 串 所 要 出 现 的 位 置 。 

如 果 是 在 目标 字符 串 开头 出 现 ， 则 使 用 符号 “^”; 如 果 是 在 目标 字符 串 结尾 出 现 ， 则 使 
用 符号 “$”。 例 如 ，^xiaoming 是 指 “xiaoming” 只 能 出 现在 目标 字符 串 开 头 。8895$ 是 指 
“8895” 只 能 出 现在 目标 字符 串 结尾 。 

有 一 个 特殊 表示 ， 即 同时 使 用 ^$ 两 个 符号 ， 就 是 “^[a-z]$”， 表 示 目 标 字符 串 要 只 包含 
从 a 到 z 的 单个 字符 。 


5.5.6 ”排除 字符 ([ 仿 ) 


符号 “^” 在 方 括号 内 所 代表 的 意义 则 完全 不 同 ， 它 表示 一 个 逻辑 “ 否 ”， 排 除 匹配 字符 
串 在 目标 字符 串 中 出 现 的 可 能 。 例 如 ，[^0-9] 表 示 目 标 字符 串 包含 从 0 到 9“ 以 外 ”的 任意 其 
他 字符 。 


5.5.7 ”括号 字符 (()) 


括号 字符 (0) 表 示 子 串 ， 所 有 对 包含 在 子 串 内 字符 的 操作 ， 都 是 以 子 串 为 整体 进行 的 ， 也 
是 把 正则 表达 式 分 成 不 同 部 分 的 操作 符 。 


5.5.8 选择 字符 (|) 
选择 字符 (|) 表 示 “ 或 ”选择 。 例 如 ，“comlecnlcom.cnlnet” 表 示 目 标 字 符 串 包含 com 或 cn 


或 com.cn 或 net。 
5.5.9 转 义 字符 与 反 斜 线 


由 于 “\” 在 正则 表达 式 中 属于 特殊 字符 ， 所 以 ， 如 果 单独 使 用 此 字符 ， 则 将 直接 表示 为 
作为 特殊 字符 的 转 义 字符 。 如 果 要 表示 反 斜 杠 字符 本 身 ， 则 应 当 在 此 字符 的 前 面 添加 转 义 字 
符 “”， 即 为 “\”。 


5.5.10 ”认证 E-mail 的 正则 表达 式 


在 处 理 表单 数据 的 时 候 ， 对 用 户 的 E-mail 进行 认证 是 十 分 常用 的 。 如 何 判断 用 户 输入 的 
是 一 个 E-mail 地 址 呢 ? 就 是 用 正则 表达 式 来 匹配 。 其 格式 如 下 : 

^[R-za-z0-9_ .]+@[A-Za-20-9 ]+N\-[R-Za-z0-9.]+$ 

其 中 ^[A-Za-z0-9 .+ 表示 至 少 有 一 个 英文 大 小 写字 符 、 数 字 、 下 划 线 、 点 号 ， 或 者 这 些 字 
符 的 组 合 。 


@ 表 示 email 中 的 “@”。 

[A-Za-z0-9_]+ 表 示 至 少 有 一 个 英文 大 小 写字 符 、 数 字 、 下 划 线 ， 或 者 这 些 字符 的 组 合 。 

\ 表 示 E-mail 中 “.com” 之 类 的 点 。 这 里 点 号 只 是 点 本 身 ， 所 以 用 反 斜 杠 对 它 进行 转 义 。 

[A-Za-z0-9.]+$ 表 示 至 少 有 一 个 英文 大 小 写字 符 、 数 字 、 点 号 ， 或 者 这 些 字符 的 组 合 ， 
且 直 到 这 个 字符 串 的 末尾 。 


5.5.11 使 用 正则 表达 式 对 字符 串 进行 匹配 


用 正则 表达 式 对 目标 字符 串 进行 匹配 是 正则 表达 式 的 主要 功能 。 

完成 这 个 操作 需要 用 到 ereg0 函 数 。 这 个 函数 是 在 目标 字符 串 中 寻找 符合 特定 正则 表达 规 
范 的 字符 串 子 串 。 根 据 指定 的 模式 来 匹配 文件 名 或 字符 串 。 其 中 ereg0 函 数 是 对 字符 大 小 写 不 
敏感 。 它 的 语法 格式 如 下 : 

ereg (正则 表达 规范 ， 目 标 字符 串 ， 数 组 ) 


下 面 的 例子 介绍 利用 正则 表达 规范 匹配 E-mail 输入 的 方法 和 技巧 。 
【 例 5.11】( 示 例文 件 : ch05\5.11.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
$email = "wangxioaming201l@hotmail .com"; 
$email2 = "The email is liuxiaoshuai 2011@hotmail.com"; 
$asemail = "This is wangxioaming2011Q@hotmail"7 
$regex = '^[a-zA-20-9_ .]+@[a-zA-20-9 ]+\.[a-zA-20-9.]+$"'; 
$regex2 = '[a-zA-20-9_ .]+@[a-zA-20-9 _]+\.[a-zA-20-9.]+$"'; 


if(ereg($regex, $email, $a)){ 
echo "This is an email."; 
print r($a); 
echo "<br />"; 
上 
if(ereg($regex?2, $email2, $b)){ 
echo “This 1s a new emails™"? 
print r($b); 
echo "<br />"; 
上 
if(ereg($regex, $asemail)){ 
echo "This is. an email.™s 
J}elsef{ 
echo "This Es not an emails™"s 
} 


Ea 


型 
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</BODY> 
</HTML> 


运行 结果 如 图 5-11 所 示 。 


合 hapyhlocalhos DD- BC X| @ localhost x| I 
文件 中 。 注 坟 (日 ”可 看 (V) 收藏 (A) 工具 (Tm 帮助 (H) 


This is an email. Array ( [0] =》wangxioaming2011@hotmail. com ) | 
This is a new email. Array ( [0] => liuxiaoshuai_20118hotmail. com ) 
This is not an email. 


翅 100% ~ 


5-11 利用 正则 表达 规范 匹配 E-mail 输入 


案例 分 析 : 

(1) $email 就 是 一 个 完整 的 E-mail 字符 串 ， 用 $regex 这 个 正则 规范 ， 也 就 是 匹配 E-mail 
的 规范 来 匹配 Semail， 得 出 的 结果 为 图 5-11 中 的 第 一 行 输出 。 

(2) 由 于 ereg0 函 数 的 格式 ，ereg($regex，$email，$a) 把 匹配 的 子 串 储存 在 名 为 $a 的 数组 
中 。print_r($a) 打 印 数组 ， 得 第 一 行 数组 的 输出 。 

(3) $email2 包含 了 完整 的 E-mail 字符 串 。 用 $regex 匹配 ， 其 返回 值 必然 为 false。 用 
Sregex2 规范 匹配 ， 其 返回 值 为 真 。 因 为 $regex2 规范 中 去 掉 了 表示 从 字符 串 头 部 开始 的 符号 
“人 ^” 。ereg($regex2,$email2, $b) 把 匹配 的 子 串 存储 在 数组 $b 中 。print_r($b) 得 到 第 二 行 数组 的 
输出 。 

(4) $asemail 字符 串 不 符合 $regex 规范 ， 返 回 值 为 false， 得 到 相应 的 输出 。 


5.5.12， 使 用 正则 表达 式 替 换 字符 串 的 子 串 


做 好 了 字符 串 及 其 子 串 的 匹配 ， 如 果 需 要 对 字符 串 的 子 串 进行 替换 ， 也 可 以 使 用 正则 表 
达 式 来 完成 。 这 种 需求 ， 比 如 是 把 输入 文本 中 的 URL 变 成 可 以 直接 点 击 的 链接 ， 此 操作 需要 
使 用 ereg_replace() 和 eregi_replace0 函 数 。 其 中 ereg_replace() 对 大 小 写 敏感 ， 而 eregi_replace() 
对 大 小 写 不 敏感 。ereg_replace0) 的 格式 为 : 

ereg_ replace (正则 表达 规范 ， 欲 取代 字符 串 子 串 ， 目 标 字符 串 ) 


以 下 例子 介绍 利用 正则 表达 式 取代 字符 串 子 串 的 方法 和 技巧 。 
【 例 $.12】( 示 例文 件 ch05\5.12.php) 


<HTML> 
<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 

<BODY> 

<?php 


$searchurl = 
"这 是 搜索 引擎 连接 : http://www.google.com/ 和 http://www.baidu.com/。"; 
echo ereg replace("(http://) ([a-zA-20-9./- ]+)", 
"<a href=\"\\0\">\\0</a>", $searchurl); 
echo "<br />"; 
echo ereg replace("(http://) ([a-zA-20-9./- ]+)","<a href=\"\\0\">\\2</a>", 
$searchurl); 
2> 
</BODY> 
</HTML> 


运行 结果 如 图 5-12 所 示 。 


克 hapy/localhos PD - BO X | Elocalhost x rx 
文件 ( 明 编辑 (E) ”可 看 (V) 收 训 (A) 工具 (T) 帮助 (H) 


这 是 搜索 引 敬 连接 ，http://www. google. com/ 和 http://www. baidu com/。 
这 是 搜索 引擎 连接 ，wmmww. google. com/ 和 www. bai du. com/。 


图 5-12 ”使 用 正则 表达 式 蔡 换 字符 串 的 子 串 


案例 分 析 : 

(1) 其 中 ，$searchurl 里 面包 含 两 个 URL 文本 。ereg_replace() 按 照 格 式 对 $searchurl 里 的 
URL 进行 匹配 替换 。 

(2) 正则 规范 为 “Chttp://)([a-zA-Z0-9./-_ ]+)”， 分 为 两 部 分 ，Chttp:/) 和 ([a-zA-Z0-9./-_ ]+) 
部 分 ， 前 者 直接 匹配 ， 后 者 用 正则 语法 匹配 。 

(3) 第 一 行 的 输出 ， 替 换 为 “<a hre 伍 "0W>W0</a>”。 里 面 的 0” 把 反 斜 杠 转 义 后 表示 的 
是 “0”*"，\0” 表 示 正 则 规则 中 所 有 部 分 匹配 的 内 容 。 第 二 行 的 输出 蔡 换 为 “<a 
href=\W\0W>W2</a>”"， 里 面 的 2” 把 反 斜 杠 转 义 后 表示 的 是 “2”"，“\2” 表 示 正 则 规则 中 第 二 部 
分 匹配 的 内 容 。 依 次 类 推 ，“\1” 表 示 的 是 第 一 部 分 匹配 的 内 容 。 


5.5.13 ”使 用 正则 表达 式 切 分 字符 串 


使 用 正则 表达 式 可 以 把 目标 字符 串 按 照 一 定 的 正则 规范 切 分 成 不 同 的 子 串 。 完 成 此 操作 
需要 使 用 到 strtokO 函 数 。 它 的 语法 格式 为 : 


strtok (正则 表达 式 规范 ， 目 标 字符 串 ) 
这 个 函数 是 指 以 正则 规范 内 出 现 的 字符 为 准 ， 把 目标 字符 串 切 分 成 若干 个 子 串 ， 并 且 存 


入 数组 。 
下 面 的 例子 介绍 利用 正则 表达 式 切 分 字符 串 的 方法 和 技巧 。 


上 | 
a 
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【 例 5.13】( 示 例文 件 ch05\5.13.php) 


<HTML> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 

<BODY> 

<?php 

$string = "Hello world. Beautiful day today."; 

$token = strtok($string, " "); 

while ($token !== false) 

{ 


echo "$token<br />"; 
$token = strtok(™" "); 
3 
区 
</BODY> 
</HTML> 


运行 结果 如 图 5-13 所 示 。 


(¢ 回 总 hapyllocalhos P - BO Xlocalhost 


文件 (站 ”编辑 (E) 坦 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


图 5-13 ”利用 正则 表达 式 切 分 字符 串 


案例 分 析 : 

(1) $string 为 包含 多 种 字符 的 字符 串 。strtok($string,“”) 对 其 进行 切 分 ， 并 将 结果 存 入 数 
组 $token。 

(2) 其 正则 规范 为 "”， 是 指 按 空格 将 字符 串 切 分 。 


5.6 创建 酒店 系统 在 线 订 房 表 单 


本 例 主 要 创建 酒店 系统 的 在 线 订 房 表 单 ， 其 中 需要 创建 两 个 PHP 文件 。 具 体 步 又 如 下 。 

ED 在 网 站 主 目录 下 建立 文件 formstringhandler.php。 输 入 以 下 代码 并 保存 : 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 


<HTML xmlns="http://www.w3.0rg/1999/xhtml"> 
<HEAD> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 


可 


您 的 订房 信息 : 

</HEAD> 

<BODY> 

<?php 

$DOCUMENT ROOT = $ SERVER['DOCUMENT ROOT']; 

$customername = trim($ POST['customername']); 

$gender = $ POST['gender']; 

$arrivaltime = $ POST[I'arrivaltime']7 

$phone = trim($ POST['phone']); 

$email = trim($ POST['email']); 

$info = trim($ POST['info']); 

if(!leregi('^[a-zA-20-9 \-\.]+@ [a-zA-20-9\-]+\.[a-zA-20-9 \-\.]+$',$email)){ 
echo "这 不 是 一 个 有 效 的 email 地 址 ， 请 返回 上 页 且 重 试 "; 


eXit7 


此 了 余 订 旦 月 过 币 韦 导 贡 9 小 加 


和 
if(!eregi('^[0-9]$',$phone) and strlen($phone)<= 4 or strlen($phone)>= 15){ 
echo "这 不 是 一 个 有 效 的 电话 号 码 ， 请 返回 上 页 且 重 试 "; 


GG 


exit; 
if($gender == "m"){ 
$customer = "先生 "; 
}else{ 


$customer = 女士 "5 
} 
echo '<p> 您 的 订房 信息 已 经 上 传 ， 我 们 正在 为 您 准备 房间 。 确认 您 的 订房 信息 如 下 :</p>"'; 
echo $customername."\t".$customer.' 将 会 在 '.$arrivaltime.' 天 后 到 达 。 您 的 电话 
为 ' .$phone."。 我 们 将 会 发 送 一 封 电子 邮件 到 您 的 email 邮箱 : " .$email."。<br /><br /> 另 
外 ， 我 们 已 经 确认 了 您 其 他 的 要 求 如 下 : <br /><br />"; 
echo nl2br ($info); 
echo "<p> 您 的 订房 时 间 为 :" .date('Y m d H: i: s')."</p>"; 
i 
</BODY> 
</HTML> 


在 网 站 主 目录 下 建立 文件 form4string.html， 输 入 以 下 代码 并 保存 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.o0rg/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 
<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 在 线 订 房 表 。</h2> 
</HEAD> 
<BODY> 
<form action="formstringhandler.php" method="post"> 
<table> 
<tr bgcolor="#3399FF"> 
<td> 客 户 姓名 :</td> 


<td><input type="text" name="customername" size="20" /></td> 
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</tr> 
<tr bgcolor="#CCCCCC"> 
<td> 客 户 性 别 : </tq> 
<td> 
<select name="gender"> 
<option value="m"> 男 </option> 
<option value="f"> 女 </option> 
</select> 
</tad> 
</tr> 
<tr bgcolor="#3399FF"> 
<td> 到 达 时 间 :</tq> 
<td> 
<select name="arrivaltime"> 
"> 一 天 后 </option> 
<option value="2"> 两 天 后 </option> 
<option value="3"> 三 天 后 </option> 
<option value="4"> 四 天 后 </option> 
<option value="5"> 五 天 后 </option> 


<option value= 


</select> 
</td> 
</Er> 
<tr bgcolor="#CCCCCC"> 
<tqd> 电 话 :</td> 
<td><input type="text" name="phone" size="20" /></td> 
</tr> 
<tr bgcolor="#3399FF"> 
<td>email:</td> 
<td><input type="text" name="email" size="30" /></td> 
EA 
<tr bgcolor="#CCCCCC"> 
<td> 其 他 需求 :</td> 
<td> 
<textarea name="info"” rows="10" cols="30"> 如 果 您 有 什么 其 他 要 求 ， 请 填 在 这 里 。 
</textarea> 
</td> 
</tr> 


<tr bgcolor="#666666"> 
<td align="center"><input type="submit" value=" 确 认 订房 信息 " /></td> 
</tr> 
</table> 
</form> 
</BODY> 
</HTML> 


运行 form4string.html， 结 果 如 图 5-14 所 示 。 


| 


如 果 您 有 什么 其 他 要 求 ， 请 填 ^ 
在 这 里 。 


图 5-14 form4string.html 的 运行 结果 


ERZ 填写 表单 。“ 客 户 姓名 ”为 “王小明 ”、“ 性 别 ” 为 “ 男 ”、“ 到 达 时 间 ” 为 
“三 天 后 ”、“ 电 话 ” 为 “13592XXXX77”、“Email ”为 “wangxiaoming@ 
hotmail.com”、“ 其 他 需求 ”为 “两 过 开水 ，【Enter】 一 条 白 毛 巾 ，【Enter)】 一 个 
冰激凌 ”。 单 击 “ 确 认 订房 信息 ”按钮 ， 浏 览 器 会 自动 跳 转 至 formstringhandler.php 
页 面 ， 显 示 如 图 5-15 所 示 的 结果 。 


Geeeceee-scxlscw | 


文件 (” 妨 名 (E) ”可 看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 
您 的 订房 信息 ， 

您 的 订房 信息 已 经 上 传 ， 我 们 正在 为 您 准备 房间 。 确认 您 的 订房 信息 如 下 : 

王小明 先生 将 会 在 3 天 后 到 达 。 您 的 电话 为 13592XXXX77。 我 们 将 会 发 送 一 封 电子 邮件 到 您 


的 email 邮 箱 ，wangxiaomingehotmail. com。 
另外 ， 我 们 已 经 确认 了 您 其 他 的 要 求 如 下 : 
两 查 开水 ，【〖Enter】 一 条 白 毛巾 ，【〖Enter] 一 个 冰激凌 
您 的 订房 时 间 为 :2014 04 19 05，00，54 


5-15 ”提交 后 的 显示 结果 


案例 分 析 : 
(1) $customerame = trim($ POST[‘customermame’]); $phone = trim($ POST[‘phone’)); 
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Semail = trim($ POST['email]): $info = trim($_ POST['info7]): 都 是 通过 文本 输入 框 直接 输入 
的 。 所以， 为 了 保证 输入 字符 串 的 纯净 ， 以 方便 处 理 ， 则 需要 使 用 trim0， 来 对 字符 串 的 前 后 
的 空格 进行 清除 。 另 外 ，ltrim0 清 除 左边 的 空格 ，rtrim0 清 除 右 边 的 空格 。 

(2) !eregi(^[a-zA-20-9_\-\.]+@[a-zA-Z0-9\-]+\.[a-zA-20-9_\-\]+$',$Semail) 中 使 用 了 正则 表 
达 式 对 输入 的 E-mail 文本 进行 判断 。 

(3) nl2br0 对 $info 变量 中 的 【Enter】 操 作 ， 也 就 是 <br 人 > 操作 符 进 行 了 处 理 。 在 有 新 行 
“\nl” 操 作 的 地 方 生成 <br />。 

(4) 由 于 要 显示 中 文 ， 需 要 对 文字 编码 进行 设置 ，charset=gb2312， 就 是 简体 中 文 的 文字 
编码 。 


5.7 疑难 解 惑 


疑问 1: 模式 修饰 符 、 单 词 界 定 符 如 何 使 用 ? 


在 PHP 的 正则 表达 式 的 语法 中 ， 一 种 是 POSIX 语法 ， 一 种 是 Perl 语法 。POSIX 语法 是 
先前 所 介绍 的 语法 。Perl 语法 则 不 同 于 POSIX 语法 。Perl 语法 的 正则 表达 是 以 “/” 开 头 和 以 
“/” 结 尾 的 ， 如 “/name/” 便 是 一 个 Perl 语法 形式 的 正则 表达 式 。 

模式 修饰 符 则 是 在 Perl 语法 正则 表示 中 的 内 容 。 比 如 “i” 表示 正则 表达 式 对 大 小 写 不 敏 
感 。“g” 表 示 找 到 所 有 的 匹配 字符 。“m” 表 示 把 目标 字符 串 作 为 多 行 字符 串 进行 处 理 。 
“s” 把 目标 字符 串 作 为 单行 字符 串 进行 处 理 ， 忽 略 其 中 的 换行 符 。“x” 表 示 忽 略 正 则 表达 式 
中 的 空格 和 备注 。“u” 表 示 在 首次 匹配 后 停止。 

单词 界定 符 也 是 Perl 语法 正则 表达 式 中 的 内 容 。 不 同 的 单词 界定 符 表示 不 同 的 字符 界定 
范围 。 比 如 以 下 单词 界定 符 所 表示 的 意义 : “\A” 表 示 仅 仅 匹 配 字 符 串 的 开头 ，“\b” 表 示 
匹配 到 单词 边界 ，“\B” 表 示 除 了 单词 边界 ， 匹 配 所 有 ; “\d” 表 示 匹 配 所 有 数字 字符 ， 等 同 
于 “[0-9]”; “\D” 表 示 匹 配 所 有 非 数 字 字 符 ，“\s” 表 示 匹 配 空格 字符 ，“\S” 表 示 匹 配 非 
空格 字符 ，“\w” 表 示 匹 配 字符 串 ， 如 同 “[a-zA-Z0-9 ]”; “\WW” 匹 配 字符 ， 忽 略 下 划 线 和 
字母 数字 字符 。 


疑问 2: 支持 Perl 语法 形式 的 正则 表达 式 有 哪些 ? 


PHP 为 Perl 语法 的 正则 表达 方式 提供 了 下 列 函 数 。 

epreg_grep0: 用 来 搜索 一 个 数组 中 的 所 有 数组 元 素 ， 以 得 到 匹配 元 素 。 

@ preg_match(): 以 特定 模式 匹配 目标 字符 串 。 

epreg_match_al0: 以 特定 模式 匹配 目标 字符 串 ， 并 且 把 匹配 元 素 作为 元 素 返回 给 一 
个 特定 的 数组 。 

preg_quote0: 在 每 一 个 正则 表达 式 的 特殊 字符 前 插入 一 个 反 斜 本 “\”。 
preg_replace0: 蔡 代 所 有 符合 正则 表达 式 的 字符 ， 并 返回 按照 要 求 修 改 的 结果 。 
preg_replace_callback0: 以 键 值 蔡 代 所 有 符合 正则 表达 式 格式 字符 的 键 名 。 
preg_split0: 按照 正则 模型 切 分 字符 串 。 
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数组 在 PHP 中 是 极为 重要 的 数据 类 型 。 本 章 将 介绍 什么 是 数组 、 数 组 包含 的 
类 型 、 数 组 的 构造 ， 以 及 遍历 数组 、 数 组 排序 、 在 数组 中 添加 和 删除 元 素 、 查 询 数 
组 中 的 指定 元 素 、 统 计数 组 元 素 的 个 数 、 删 除数 组 中 重复 的 元 素 、 数 组 的 序列 化 等 
操作 。 通 过 本 章 的 学 习 ， 读 者 可 以 掌握 数组 的 常用 操作 和 使 用 技巧 。 
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6.1 什么 是 数组 


什么 是 数组 ? 数组 就 是 被 命名 的 用 来 储存 一 系列 数值 的 地 方 。 数 组 array 是 非常 重要 的 数 
据 类 型 。 相 对 于 其 他 的 数据 类 型 ， 它 更 像 是 一 种 结构 ， 而 这 种 结构 可 以 储存 一 系列 数值 。 

数组 中 的 数值 被 称 为 数组 元 素 。 而 每 一 个 元 素 都 有 一 个 对 应 的 标识 ， 也 称 作 键 值 。 通 过 
这 个 标识 ， 可 以 访问 数组 元 素 。 数 组 的 标识 可 以 是 数字 ， 也 可 以 是 字符 串 。 

例如 一 个 班级 通常 有 十 几 个 人 ， 如 果 需 要 找 出 某 个 学 生 ， 可 以 利用 学 号 来 区 分 每 一 个 学 
生 ， 这 时 ， 班 级 就 是 一 个 数组 ， 而 学 号 就 是 下 标 ， 如 果 指 明 学 号 ， 就 可 以 找到 对 应 的 学 生 。 


6.2 数组 类 型 
数组 分 为 数字 索引 数组 和 关联 数组 。 本 节 将 详细 讲述 这 两 种 数组 的 使 用 方法 。 
6.2.1 数字 索引 数组 


数字 索引 数组 是 最 常见 的 数组 类 型 ， 默 认 从 0 开始 。 数 组 变量 可 以 随时 创建 和 使 用 。 

声明 数组 的 方法 有 两 种 。 

(1) 使 用 arrayO 函 数 声明 数组 。 声 明 数 组 的 具体 方式 如 下 ; 

array 数组 名 称 ( [mixead] ) 

其 中 参数 mixed 的 语法 为 key=>value。 如 果 有 多 个 mixed， 可 以 用 逗号 分 开 ， 分 别 定义 了 
索引 和 值 : 

be, sd oa de el 

利用 array0 函 数 来 定义 比较 方便 和 灵活 ， 可 以 只 给 出 数组 的 元 素 值 ， 而 不 必 给 出 键 值 
例如 : 

$arr = array ("空调 "， "冰箱 "， "洗衣 机 "， "电视 机 ") ; 

(2) 通过 直接 为 数组 元 素 赋值 的 方式 声明 数组 。 

如 果 在 创建 数组 时 不 知道 数组 的 大 小 ， 或 者 数组 的 大 小 可 能 会 根据 实际 情况 发 生变 化 ， 


此 时 可 以 使 用 直接 赋值 的 方式 声明 数组 。 
例如 : 
$arr[1] =“" 空 调 "; 
$arr[2] = "冰箱 " 
$arr[3] = "洗衣 机 "7 
$arr[4] = “" 电 视 机 "; 


下 面 以 酒店 网 站 系统 中 的 酒店 房价 为 例 进 行 讲 解 。 


【 例 6.1】( 示 例文 件 ch06\6.1.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www-w3.org/TR/xhtml1/VDTD/xhtml1-transitional.dtd"> 

<HTML xmlns="http://www-w3.-org/1999/xhtml"> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<h2>GoodHome 房间 类 型 。</h2> 

</HEAD> 

<BODY> 

<?php 

$roomtypes = array(' 单 床 房 ', ' 标 准 间 ', ' 三 床 房 ', 'VIP 套房 ' ) ; 

echo $roomtypes[0]."\t".$roomtypes[1]."\t" 

.$roomtypes[2]."\t".$roomtypes[3]."<br />"; 

echo "$roomtypes[0] $roomtypes[1] $roomtypes[2] $roomtypes[3] <br />"; 

$roomtypes[0] = ' 单 人 大 床 房 '; 

echo "$roomtypes[0] $roomtypes[1] $roomtypes[2] $roomtypes[3]<br />"; 

2 

</BODY> 

</HTML> 


运行 结果 如 图 6-1 所 示 。 


【€ [ET | 


文件 (站 久 名 (E) 喜 看 (V) ”收藏 关 (A) 工具 (T) ”部 且 (H) 
GoodHome 房 间 类 型 。 
单 床 房 标准 间 上司 汉 7 二 


单 床 房 标准 间 三 
单 人 大 床 房 a A Vs 


图 6-1 创建 和 使 用 数组 


案例 分 析 : 

(1) 这 里 ，$roomtypes 为 一 维 数组 ， 用 关键 字 array 声明 。 并 且 用 “=” 赋 值 给 数组 变量 
S$roomtypes。 

(2) (' 单 床 房 ",' 标 准 间 ,“ 三 床 房 ','VIP 套房 为 数组 元 素 ， 且 这 些 元 素 为 字符 串 型 ， 用 单 
引号 “方式 表示 。 每 个 数组 元 素 用 “,.” 分 开 。echo 命令 直接 打印 数组 元 素 ， 元 素 索 引 默 认 从 
0 开始 ， 所 以 第 一 个 数组 元 素 为 Sroomtypes[0]。 

(3) 数组 元 素 可 以 直接 通过 “=” 号 赋值 ， 如 $roomtypes[0] = “ 单 人 大 床 房 *; echo 打印 后 
为 “ 单 人 大 床 房 ”。 
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6.2.2 ”关联 索引 数组 


关联 数组 的 键 名 可 以 是 数值 和 字符 串 混 合 的 形式 ， 而 不 像 数字 索引 数组 的 键 名 只 能 为 数 
字 。 所 以 判断 一 个 数组 是 否 为 关联 数组 的 依据 是 : 数组 中 的 键 名 是 否 存在 一 个 不 是 数字 的 ， 
如 果 存 在 ， 则 为 关联 数组 。 

下 面 以 使 用 关联 索引 数组 编写 酒店 房间 类 型 为 例 进 行 讲解 。 

【 例 6.2】( 示 例文 件 ch06\6.2.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0org/TR/xhtmll1/DTD/xhtmll-transitional.dtd"> 

<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<h2>GoodHome 房间 类 型 。</h2> 

</HEAD> 

<BODY> 

<?php 

$prices per day = 
array (' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 

echo $prices_per_day[' 标 准 间 '] ."<br />"; 
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</BODY> 
</HTML> 
运行 结果 如 图 6-2 所 示 。 
[¢ 轿 @ htpy/localhost P - SOX|@ localhost 
文件 (月 编 回 (5) 得 看 (V) ”收藏 关 (A) 工具 (T) 者 助 (H) 
GoodHome 房 间 类 型 。 
268 
图 6-2 使 用 关联 索引 数组 
案例 分 析 : 


这 里 ，echo 命令 直接 指定 数组 $prices_per_day 中 的 关键 字 索 引 ‘ 标 准 间 *( 是 个 字符 串 ) 便 可 
打印 出 数组 元 素 268( 是 一 个 整 型 数 )。 


Gu 


6.3 数组 的 结构 
按照 数组 的 结构 来 分 ， 可 以 把 数组 分 为 一 维 数组 和 多 维 数组 。 


6.3.1 一 维 数组 


数组 中 每 个 数组 元 素 都 是 单个 变量 ， 不 管 是 数字 索引 还 是 联合 索引 ， 这 样 的 数组 为 一 维 
数组 。 
【 例 6.3】( 示 例文 件 ch06\6.3.php) 


<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
</HEAD> 
<BODY> 
<?php 
$roomtypes = array(' 单 床 房 ',' 标 准 间 '，,' 三 床 房 ', 'VIP 套房 ' ) ; 
$prices per day = 
array (' 单 床 房 '=> 298,' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
入 > 
</BODY> 
</HTML> 


其 中 的 Sroomtypes 和 S$prices_per_day 都 是 一 维 数组 。 


6.3.2 ”多维 数组 


数组 也 是 可 以 “ 嵌 套 ”的 ， 即 每 个 数组 元 素 也 可 以 是 一 个 数组 ， 这 种 含有 数组 的 数组 就 
是 多 维 数组 。 例 如 : 


<?php 
$roomtypes = array (array('type'=>' 单 床 房 '， 
'info'=>' 此 房间 为 单 人 单间 。'， 
"Price per day'=>298 
)， 
array ('type'=>' 标 准 间 '， 
"info'=>' 此 房间 为 两 床 标准 配置 。' ， 
"Price per day'=>268 
)， 
array ('type'=>' 三 床 房 '， 
'info'=>' 此 房间 备 有 三 张 床 '， 
'price per day'=>198 
his 
array ('type'=>'VIP 套房 '， 
"info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 


"price per day'=>368 
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2 


其 中 的 Sroomtypes 就 是 多 维 数 组 。 这 个 多 维 数组 其 实 包 含 了 两 个 维 数 。 有 点 像 数 据 库 的 
表格 ， 在 第 一 个 array 里 面 的 每 个 数组 元 素 都 是 一 个 数组 ， 而 这 些 数组 就 像 是 数据 二 维 表 中 的 
一 行 记 录 。 这 些 包含 在 第 一 个 array 里 面 的 array 又 都 包含 三 个 数组 元 素 ， 分 别 是 三 个 类 型 的 
信息 ， 这 就 像 是 数据 二 维 表 中 的 字段 。 

上 面 的 数组 如 果 绘 制 成 图 ， 效 果 如 图 6-3 所 示 。 


4| A B C D 
type info price_per_day 
2 单 床 房 此 房间 为 单 人 单间 。 298 array 
3 标准 间 此 房间 为 两 床 标准 配置 。 268 array 
4 ， 三 床 房 此 房间 备 有 三 张 床 198 
5 此 房间 为 VIPI 
6 


6-3 ”二 维 数组 的 直观 图 示 


其 实 ，$roomtypes 就 代表 了 这 样 一 个 数据 表 。 
也 可 能 出 现 两 维 以 上 的 数组 ， 比 如 三 维 数组 。 例 如 ， 


<?php 
$building = array (array (array ('type'=>' 单 床 房 '， 
'info'=>' 此 房间 为 单 人 单间 。'， 
"Price per day'=>298 
), 
array ('type'=>' 标 准 间 '， 
"'info'=>' 此 房间 为 两 床 标准 配置 。'， 
"Price per day'=>268 
)， 
array('type'=>' 三 床 房 '， 
"info'"=>" 此 房间 备 有 三 张 床 '， 
"Price_per_day'=>198 
)， 
array('type'=>'VIP 套房 '， 
"'info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
"price per day'=>368 
) 
), 
array (array ('type'=>' 普 通 餐 厅 包 房 '， 
"info'=>' 此 房间 为 普通 餐厅 包 房 。'， 
"roomid'=>201 
)， 
array('type'=>! 多 人 和 餐厅 包 房 '， 
"'info'=>' 此 房间 为 多 人 和 餐厅 包 房 。'， 
"Foomid'=>206 
)， 
array ('type'=>' 豪 华 餐 厅 包 房 '， 
"'info'=>' 此 房间 为 豪华 餐厅 包 房 。'， 


六 加 


"roomid'=>208 
}s 
array ('type'=>'VIP 餐厅 包 房 '， 
"info'=>' 此 房间 为 VIP 餐厅 包 房 '， 


'roomid'=>310 


凡 洋 二 兴国 


人 > 


这 个 三 维 数组 在 原来 的 二 维 数组 后 面 又 增加 了 一 个 二 维 数组 ， 给 出 了 和 餐厅 包 房 的 数据 二 
维 表 信息 。 把 这 两 个 二 维 数组 作为 更 外 围 array 的 两 个 数组 元 素 ， 就 产生 了 第 三 维 。 这 个 表述 
等 于 用 两 个 二 维 信息 表 表 示 了 一 个 名 为 Sbuilding 的 数组 对 象 ， 如 图 6-4 所 示 。 


E 


| | A B i 


type info price per_day 
单 订房 此 房间 为 单 人 单间 。 298 array 
标准 间 此 谎 间 为 两 床 标准 配置 - 268 array 
房 此 房间 备 床 


此 房间 光 普 通 餐 厅 包 房 
此 房间 为 多 人 餐厅 包 房 
此 房间 为 豪华 餐厅 包 房 。 
此 房间 为 YIP 餐 厅 1 

ARRAY (= 


ARRAY (三 维 ) 


图 6-4 三 维 数组 的 直观 图 示 


py A 


6.4 遍历 数组 
所 谓 数组 的 遍历 ， 是 要 把 数组 中 的 变量 值 读 取出 来 。 下 面 讲述 常见 的 遍历 数组 的 方法 。 


6.4.1 遍历 一 维 数字 索引 数组 


下 面 讲解 如 何 通过 循环 语句 遍历 一 维 数字 索引 数组 。 此 案例 中 使 用 到 了 for 循环 ， 以 及 
foreach 循环 。 
【 例 6.4】( 示 例文 件 ch06\6.4.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 
<HTML xmlns="http://www.w3.0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 房间 类 型 。</h2> 
</HEAD> 
<BODY> 
<?php 
$roomtypes = array(' 单 床 房 ',' 标 准 间 ',' 三 床 房 ', 'VIP 套房 ' ) ; 
for ($i=0; S$i<3; $i++){ 
echo $roomtypes[$i]."” (for 循环 ) <br />"; 
} 
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foreach ($roomtypes as S$room){ 
echo $room." (foreach 循环 ) <br />"; 
¥ 


汪洋 
</BODY> 
</HTML> 
运行 结果 如 图 6-5 所 示 。 
人 Se hupy/localhost PD = SOX] 
文件 (第 {查看 (V) ”收藏 拓 (A) 工具 (T 帮助 (H) 
GoodHome 房 间 类 型 。 
单 床 房 for 循环) 
标准 间 。 (for 循环) 
三 床 房 〈for 循 环 ) 
单 床 房 (foreach 箱 环 ) 
标准 间 (foreach 循 环 ) 
三 床 房 (foreach 特 环 ) 
UP 套 房 (foreach 箱 环 ) 
图 6-5 遍历 一 维 数字 索引 数组 
案例 分 析 : 


(1) for 循环 只 进行 了 0、1、2， 共 三 次 。 
(2) foreach 循环 则 列 出 了 数组 中 所 有 的 数组 元 素 。 


6.4.2 ”遍历 一 维 联合 索引 数组 


下 面 以 遍历 酒店 房间 类 型 为 例 ， 对 联合 索引 数组 进行 遍历 。 
【 例 6.5】( 示 例文 件 ch06\6.5.php) 


<!IDOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtmll1/DTD/xhtmll-transitional.dtd"> 
<HTML xmlns="http://www.w3.0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 房间 类 型 。</h2> 
</HEAD> 
<BODY> 
<?php 
$prices per day = 
array(" 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
foreach ($prices per day as $price){ 
echo $price."<br />"; 
} 
foreach ($prices per day as $key => $value){ 
echo $key.":".$value."” 每 天 。<br />"; 
} 


reset ($prices per day); 


while ($element = each($prices per day)){ 
echo $element['key']."\t"; 
echo $element['value']; 
echo "<br />"; 

} 


reset ($prices per day); 


while (list($type, $price) = each($prices per day)){ 


echo "$type - $price<br />"; 
} 
?> 
</BODY> 
</HTML> 


运行 结果 如 图 6-6 所 示 。 


大 hpi/localhost PD - 8 cx | Blocalhost 


I 


文件 婉 句 (E) 查看 (V) ”收藏 闪 (A) 工具 [T) 帮助 (H) 


GoodHome 房 间 类 型 。 


368 
单 床 房 :298 每 天 。 
标准 间 :268 每 天 。 
三 床 房 :198 每 天 。 


图 6-6 ”遍历 一 维 联合 索引 数组 


案例 分 析 : 


(1) foreach ($prices_per_day as $price)f 遍历 了 数组 元 素 ， 所 以 输出 4 个 整 型 数值 。 而 
foreach ($prices_per day as $key => $value){} 则 除了 遍历 数组 元 素 ， 还 遍历 了 其 所 对 应 的 关键 


字 ， 如 人 单 床 房 " 是 数组 元 素 298 的 关键 字 。 


(2) 这 段 程序 中 使 用 了 while 循环 。 还 用 到 了 几 个 新 的 函数 reset0、eachO0 和 list0。 由 于 
在 前 面 的 代码 中 ，Sprices_per_day 已 经 被 foreach 循环 遍历 过 ， 而 内 存 中 的 实时 元 素 为 数组 的 
最 后 一 个 元 素 ， 因 此 ， 如 果 想 用 while 循环 来 遍历 数组 ， 就 必须 用 reset0 函 数 ， 把 实时 元 素 重 
新 定义 为 数组 的 开头 元 素 。eachO 则 是 用 来 遍历 数组 元 素 及 其 关键 字 的 函数 。list0 是 把 eachO 


中 的 值 分 开 赋值 和 输出 的 函数 。 
6.4.3 遍历 多 维 数组 


下 面 以 使 用 多 维 数组 编写 房间 类 型 为 例 进行 遍 历 ， 具 体操 作 步 骤 如 下 。 


篇 
od 


小 溢 “ 册 9 小 面 症 


py A 


i109@ 


PHP+MySQL 动 态 网 站 开发 
案例 课 演 


【 例 6.6】( 示 例文 件 ch06\6.6.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www-w3.-org/TR/xhtml1/DTD/xhtm1l1-transitional.dtd"> 
<HTML xmlns="http://www-w3-org/1999/xhtml1"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 房间 类 型 (多 维 数组 ) 。</h2> 
</HEAD><BODY> 
<?php 
$roomtypes = array (array('type'=>' 单 床 房 '， 
"info'=>'" 此 房间 为 单 人 单间 。'， 
"Price Per day'=>298 
Ws 
array('type ' 标 准 间 '， 
"'info'=>' 此 房间 为 两 床 标准 配置 。'， 
'price per day'=>268 
), 
array('type' 三 床 房 '， 
"info'=>' 此 房间 备 有 三 张 床 '， 
"Price per day'=>198 
), 
array ('type'=>'VIP 套房 '， 
'info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
"Price Per day'=>368 


1 
for ($row=0; $row<4; $rowt++){ 
while (list($key, $value) = each($roomtypes[$row])){ 
echo "$key:$value"."\t |"; 
} 
echo <br /> 
} 
> 
</BODY></HTML> 


运行 结果 如 图 6-7 所 示 。 


大 upyioualhust PP - CX 有 | 短 Iocalhost x I 
文件 (站 蝗 各 (E) 喜 看 V】 收藏 均 A) 工具 Mm 者 动 (H) 


GoodHome 房 间 类 型 (多 维 数组 )。 


床 房 |info: 此 房间 为 单 人 单间 。_|price_per_day:298 | 

间 |info: 此 房间 为 两 床 标准 配置 。 |price_per_day:268 | 
三 床 房 |info: 此 房间 备 有 三 张 床 |price_per_day:198 | 
:WP 套房 |info: 此 房间 为 YIP 两 间 内 外 套房 |price_per_day:368 | 


6-7 ”遍历 多 维 数组 


加 


案例 分 析 : 

(1) Sroomtypes 中 的 每 个 数组 元 素 都 是 一 个 数组 ， 而 作为 数组 元 素 的 数组 又 都 有 三 个 拥 
有 键 名 的 数组 元 素 。 

(2) 使 用 for 循环 配合 eachO、1listO 函 数 来 遍历 数组 元 素 ， 便 得 到 输出 。 


监 岂 直 9 小 四 


6.5 数组 排序 
本 节 主 要 讲述 如 何 对 一 维和 多 维 数组 进行 排序 操作 。 


6.5.1 一 维 数组 排序 


以 下 示例 展示 如 何 对 数组 进行 排序 。 
【 例 6.7】( 示 例文 件 : ch06\6.7.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 
<HTML xmlns="http://www.w3.0org/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 房间 类 型 。</h2> 
</HEAD> 
<BODY> 
<?php 
$roomtypes = array(' 单 床 房 ',' 标 准 间 '，,' 三 床 房 ', 'VIP 套房 ' ) ; 
$prices per day = 
array (' 单 床 房 '=> 298,' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
sort ($roomtypes); 
foreach ($roomtypes as $key => $value){ 
echo $key.":".$value."<br />"; 


GG 


asort ($prices per day); 
foreach ($prices per day as $key => $value){ 
echo $key.":".$value." 每 日 。<br />"; 


ksort ($prices per day); 
foreach ($prices per day as $key => $value){ 
echo $key.":".$value." 每 天 。<br />"; 


rsort ($roomtypes); 
foreach ($roomtypes as $key => $value){ 
echo $key.":".$value."<br />"; 


arsort ($prices per day); 

foreach ($prices per day as $key => $value){ 
echo $key.":".$value." 每 日 。 <br />"; 

1 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 B- 


krsort ($prices per day); 


} 


?> 
</BODY> 
</HTML> 


运行 结果 如 图 6-8 所 示 。 


foreach ($prices per day as $key => $value){ 
echo $key.":".$value." 每 天 。<br />"; 


httpi//localhost 局 - 虽 CX | 车 localhost 


I 


文件 (F) 编辑 (E) 章 看 (V) 收藏 天 (A) 工具 (T) 帮助 (H) 


GoodHome 房 间 类 型 。 


:198 每 天 。 
单 床 房 :298 每 天 。 
标准 间 :268 每 天 。 
VIP 套 房 :368 每 天 。 


6-8 ”对 一 维 数组 进行 排序 


案例 分 析 : 


(1) 这 段 代 码 是 关于 数组 排序 的 内 容 ， 涉 及 到 sort)、asortD)、ksortO0 、rsortO 、arsortO、 
krsort()。 其 中 ，sort0 是 默认 排序 。asort0 根 据 数组 元 素 的 值 的 升序 排序 。ksort0 是 根据 数组 元 


素 的 键 值 ， 也 就 是 关键 字 的 升序 排序 。 


(2) rsort0、arsort0、krsort0 则 正好 与 所 对 应 的 升序 排序 相反 ， 都 为 降序 排序 。 


6.5.2 ”多维 数组 排序 


对 于 一 维 数组 ， 通 过 sort0 等 一 系列 的 排序 函数 ， 就 可 以 对 它 进行 排序 。 而 对 于 多 维 数 
组 ， 排 序 就 没有 那么 简单 了 。 首 先 需要 设 定 一 个 排序 方法 ， 也 就 是 建立 一 个 排序 函数 ， 再 通 
过 usort0 函 数 对 特定 数组 采用 特定 排序 方法 进行 排序 。 下 面 的 案例 介绍 多 维 数组 排序 。 


【 例 6.8】( 示 例文 件 ch06\6.8.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 


信心 


<HTML xmlns="http://www.w3.org/1999/xhtml"> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 房间 类 型 (多 维 数组 ) 。</h2> 

</HEAD> 

<BODY> 


<?php 
$roomtypes = array (array('type'=>" 单 床 房 ' 了 
"'info'=>' 此 房间 为 单 人 单间 。'， 
'price per day'=>298 
), 
array ('type'=>' 标 准 间 '， 
"'info'=>' 此 房间 为 两 床 标准 配置 。'， 
"price_ per day'=>268 
), 
array ('type'=>' 三 床 房 '， 
'info'=>' 此 房间 备 有 三 张 床 '， 
"Price per day'=>198 
), 
array ('type'=>'VIP 套房 '， 
"info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
"Price Per day'=>368 
) 
js 
function compare ($x, $y){ 
if ($x['price per day'] == $y['price per day']){ 
return 0; 
yelse if ($x{"price per day'l] < $y['"price per day’'l){ 
return =—13 
}elsef{ 
return 1; 


usort ($roomtypes, 'compare'); 


for ($row=0; $row<4; $row++){ 
reset ($roomtypes [$row]); 
while (list($key, $value) = each($roomtypes[$row])){ 
echo "$key:$value"."\t |"7 


} 
echo '<br />'; 
?> 
</BODY> 
</HTML> 
运行 结果 如 图 6-9 所 示 。 
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Oe /reo - sox localhost x I 
文件 (站 ” 编 强 (E) ”查看 (V) ” 收 巷 夫 (A) 工具 (T) 帮 动 (H) 


GoodHome 房 间 类 型 (多维 数组 ) 。 


type: 三 床 房 |info: 东 记 加 各 有 二 张 床 |price_per_day:198 | 

type: 标 准 间 |info: 此 房间 为 两 床 标准 配置 。 |price_per ey: 268 | 
type: 单 床 房 |info: 共 吉 入 是 攻 。 |price_per_day:298 | 
type:VIP 套 房 |info: 此 房间 为 VIP 两 间 内 外 套房 区 368 | 


R100% ~ 


图 6-9 对 多 维 数 组 进行 排序 
案例 分 析 : 
(1) 函数 compare0 定 义 了 排序 方法 ， 通 过 对 price_per_day 这 一 数组 元 素 的 对 比 ， 进 行 排 
序 。 然 后 usort() 采 用 compare 方法 对 $roomtypes 这 一 多 维 数组 进行 排序 。 
(2) 如 果 这 个 排序 的 结果 是 正 向 排序 ， 怎 么 进行 反 向 排序 呢 ? 这 就 需要 对 排序 方法 进行 
调整 。 其 中 ，recompare() 就 是 上 一 段 程 序 中 compareO 的 相反 判断 ， 同 样 采用 usort0 函 数 输出 
后 ， 得 到 的 排序 正好 与 前 一 段 程 序 输出 顺序 相反 。 


6.6 ”字符 串 与 数组 的 转换 


使 用 explode 和 implode 函数 来 实现 字符 串 和 数组 之 间 的 转换 。explode 用 于 把 字符 串 按 
照 一 定 的 规则 拆 分 为 数组 中 的 元 素 ， 并 且 形 成 数组 。implode 函数 用 于 把 数组 中 的 元 素 按照 一 
定 的 连接 方式 转换 为 字符 串 。 

下 面 的 例子 介绍 如 何 使 用 explode 和 implode 函数 来 实现 字符 串 和 数组 之 间 的 转换 。 

【 例 6.9】( 示 例文 件 ch06\6.9.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0org/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 
<HTML xmlns="http://www.w3.0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 字 符 串 与 数组 之 间 的 转换 。</h2> 
</HEAD> 
<BODY> 
<?php 
$prices per day = 
array (' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
echo implode (' 元 每 天 / ',$prices per day).'<br />'; 
$roomtypes =' 单 床 房 ,标准 间 , 三 床 房 , VIP 套房 ' ; 
print r(explode(',',$roomtypes)); 
3 
</BODY> 
</HTML> 


Gi 


运行 结果 如 图 6-10 所 示 。 


Oe ren s- sox Blocalhost x es 
文件 (有 ” 编 强 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 


字符 串 与 数组 之 间 的 转换 。 


298 元 每 天 / 268 元 每 天 / 198 元 每 天 / 368 
Array( [0] =》 单 床 房 [1] => 标准 间 [2] => 三 床 房 [3] => YIP 套房 ) 


质 100% ~ 


6-10 使 用 explode 和 implode 函数 来 实现 字符 串 和 数组 之 间 的 转换 


案例 分 析 : 

(1) Sprices_per_day 为 数组 。implode(' 元 每 天 /", $prices_per_day) 对 $prices_per_day 中 的 数 
组 元 素 中 间 添 加 连接 内 容 ， 也 叫 元 素 胶水 (glue)， 把 它们 连接 成 一 个 字符 串 输 出 。 这 个 元 素 胶 
水 (glue) 只 在 元 素 之 间 。 

(2) $roomtypes 为 一 个 由 “,” 号 分 开 的 字符 串 。explode(,'，S$roomtypes) 确 认 分 隔 符 为 
“,” 号 后 ， 以 “,” 号 为 标记 把 字符 串 中 的 字符 分 为 4 个 数组 元 素 ， 并 且 生 成 数组 返回 。 


6.7 ”向 数组 中 添加 和 删除 元 素 
数组 创建 完成 后 ， 用 户 还 可 以 继续 添加 和 删除 元 素 ， 从 而 满足 实际 工作 的 需要 。 
6.7.1 向 数组 中 添加 元 素 


数组 是 数组 元 素 的 集合 。 如 果 向 数组 中 添加 元 素 ， 就 像 是 往 一 个 盒子 里 面 放 东西 。 这 就 
牵扯 到 了 “先进 先 出 ”或 是 “后 进 先 出 ”的 问题 : 

e@ ”先进 先 出 有 点 像 排 队 买 火车 票 。 先 进 到 购买 窗口 区 域 的 ， 购 买 完成 之 后 从 旁边 的 出 

口 出 去 。 

e@ ”后 进 先 出 有 点 像 是 给 枪 的 弹 夹 上 子弹 。 最 后 押 上 的 那 一 颗 子 弹 是 要 最 先 打 出 去 的 。 

PHP 对 数组 添加 元 素 的 处 理 使 用 push、pop、shift 和 unshift 函数 来 实现 ， 可 以 实现 先进 
先 出 ， 也 可 以 实现 后 进 先 出 。 

下 面 的 例子 介绍 在 数组 前 面 添加 元 素 ， 以 实现 后 进 先 出 。 

【 例 6.10】( 示 例文 件 ch06\6.10.php) 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 

"http://www.w3.o0rg/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 

<HTML xmlns="http://www.w3.0org/1999/xhtml"> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 


<h2> 数 组 元 素 添加 之 后 进 先 出 。</h2> 


</HEAD> 
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<BODY> 

<?php 
$clients = array(' 李 丽 丽 ',' 赵 大 勇 ',' 方 芳 芳 ') ; 
array_unshift ($clients,' 王 小 明 ', ' 刘 小 帅 '); 
print r($clients); 

2 

</BODY> 

</HTML> 


运行 结果 如 图 6-11 所 示 。 


@ hupi/flocalhost P - BO Xlocalhost 
文件 (久久 (E) 可 看 (V)】 收 庆 夫 (A) 工具 (T 帮助 (H) 


数组 元 素 添加 之 后 进 先 出 。 


Array 〔 [0] => 王小明 [1] => 刘 小 帅 [2] =》 李 丽 丽 [3] =》 赵 大 勇 [4] =》 方芳 芳 ) 


图 6-11 实现 后 进 先 出 


案例 分 析 : 

(1) 数组 $clients 原本 拥有 三 个 元 素 。array_unshiftO 向 数组 $clients 的 头 部 添加 了 数组 元 素 
‘王小明 *、' 刘 小 是 *。 最 后 通过 print_r0 输 出 ， 通 过 其 数字 索引 可 以 知道 添加 元 素 的 位 置 。 

(2) array_unshift0 函 数 的 格式 为 : 

array_unshift (目标 数组 ，[ 欲 添加 数组 元 素 1， 欲 添加 数组 元 素 2，.. . ]) 


用 同样 的 例子 介绍 在 数组 后 面 添 加 元 素 ， 以 实现 先进 先 出 。 
【 例 6.11】( 示 例文 件 ch06\6.11.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/Vxhtml1-transitional.dtd"> 
<HTML xmlns="http://www.w3.org/1999/xhtm1l"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 数 组 元 素 添加 之 先进 先 出 。</h2> 
</HEAD> 
<BODY> 
<?php 
$clients = array (' 李 丽 丽 ', ' 赵 大 勇 ', ' 方 芳 芳 ' ) ; 
array push ($clients,，' 王 小 明 ', ' 刘 小 帅 '); 
print r($clients); 
党 和 
</BODY> 
</HTML> 


运行 结果 如 图 6-12 所 示 。 


信 i'e 


四 这 


Oe w/o o- SOx 


数组 元 素 添加 之 先进 先 出 。 


bl Pe 


Array (〈 [0] =》 李 丽 丽 [1] =》 赵 大 勇 [2] =》 方芳 芳 [3] => 王小明 [4] => 刘 小 帅 ) 


6-12 ”实现 先进 先 出 


案例 分 析 : 

(1) 数组 $clients 原本 拥有 三 个 元 素 。array_push0 向 数组 $clients 的 尾部 添加 了 数组 元 素 
“王小明 *、“ 刘 小 是 *"。 最 后 通过 print_r0 输 出 ， 通 过 其 数字 索引 可 以 知道 添加 元 素 的 位 置 。 

(2) array_push() 函 数 的 格式 为 : 

array_push (目标 数组 ， [ 欲 添加 数组 元 素 1， 欲 添加 数组 元 素 2，.. . ] ) 


push 的 意思 就 是 “ 推 ”的 意思 ， 这 个 过 程 就 像 是 排队 的 时 候 把 人 从 队伍 后 面向 前 推 。 


6.7.2 ”从 数组 中 删除 元 素 


从 数组 中 删除 元 素 是 添加 元 素 的 逆 过 程 。PHP 使 用 array_shift0 和 array_pop0 函 数 分 别 从 
数组 的 头 部 和 尾部 删除 元 素 。 

下 面 的 例子 介绍 如 何在 数组 前 面 删除 第 一 个 元 素 并 返回 元 素 值 。 

【 例 6.12】( 示 例文 件 ch06\6.12.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1l/DTD/xhtmll-transitional.dtd"> 


IGG 


<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 删 除数 组 开头 的 第 一 个 元 素 。</h2> 
</HEAD> 
<BODY> 
<?php 
$services = array(' 洗 衣 ', ' 订 餐 ',' 导 游 ', ' 翻 译 '); 
$deletedservices = array shift($services); 
echo $deletedservices."<br />"; 
print r($services); 
?> 
</BODY> 
</HTML> 


运行 结果 如 图 6-13 所 示 。 
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总 httpy/localhost DP- 昌 CX | 全 localhos x [全 和 文王 2 
文件 篇 碍 E) ”可 看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


删除 数组 开头 的 第 一 个 元 素 。 


洗衣 
Array ( [0] => 订餐 [1] => 导游 [2] => 翻译 ) 


6-13 ”在 数组 前 面 删 除 第 一 个 元 素 


案例 分 析 : 

(1) 数组 $services 原本 拥有 4 个 元 素 。array_shift0) 从 数组 $services 的 头 部 删除 了 第 一 个 
数组 元 素 ， 并 且 直 接 把 所 删除 的 元 素 值 返回 ， 且 赋值 给 了 变量 $deletedservices。 最 后 通过 echo 
输出 gdeletedservices， 并 用 print_r0 输 出 $services。 

(2) array_shiftO 函 数 仅仅 删除 目标 数组 的 头 一 个 数组 元 素 。 它 的 格式 如 下 : 


array_shift (目标 数组 ) 


以 上 例子 为 数字 索引 数组 ， 如 果 是 带 键 值 的 联合 索引 数组 ， 它 的 效果 相同 ， 返 回 所 删除 
元 素 的 元 素 值 。 

下 面 用 同样 的 例子 介绍 如 何在 数组 后 面 删除 最 后 一 个 元 素 并 返回 元 素 值 。 

【 例 6.13】( 示 例文 件 ch06\6.13.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1l/DTD/xhtmll-transitional.dtd"> 


<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 删 除数 组 结尾 的 最 后 一 个 元 素 。</h2> 


</HEAD> 


<BODY> 
<?php 
$services = array('sl'=>' 洗 衣 ', 's2'=>' 订 和 餐 ','s3'=>' 导 游 ', 's4'=>' 翻 译 '); 
$deletedservices = array pop($services); 
echo $deletedservices."<br />"; 
print r($services); 
党 
</BODY> 
</HTML> 


运行 结果 如 图 6-14 所 示 。 


全 1 


碟 httpi//localhost DP ~ BOX| localhost x I 
文件 ( ”编程 (E) ”可 看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


| 删除 数组 结尾 的 最 后 一 个 元 素 。 


翻译 
Array ( [sl] = 洗衣 [s2] => 订餐 [s3] => 导游 ) 


图 6-14 在 数组 后 面 删 除 最 后 一 个 元 素 


案例 分 析 : 

(1) 数组 $services 原本 拥有 4 个 元 素 。array_ pop0 〇 从 数组 $services 的 尾部 删除 了 最 后 一 个 
数组 元 素 ， 并 且 直 接 把 所 删除 的 元 素 值 返回 ， 且 赋值 给 了 变量 $deletedservices。 最 后 通过 echo 
输出 8deletedservices， 并 用 print_r0 输 出 $services。 

(2) array_pop0 函 数 仅 仅 删 除 目标 数组 的 最 后 一 个 数组 元 素 。 它 的 格式 如 下 : 

array_pop (目标 数组 ) 


这 个 例子 中 的 数组 是 一 个 联合 数组 。 


6.8 查询 数组 中 的 指定 元 素 


数组 是 一 个 数据 集合 。 能 够 在 不 同类 型 的 数组 和 不 同 结构 的 数组 内 确定 某 个 特定 元 素 是 
否 存在 ， 是 必要 的 。PHP 提供 in_array0O、array_key_exists0、array_search0、array_keysO0 和 
array_values() 函 数 ， 可 以 按照 不 同 的 方式 来 查询 数组 元 素 。 

下 面 的 例子 介绍 如 何 查询 数字 索引 数组 和 联合 索引 数组 ， 并 且 都 是 一 维 数组 。 

【 例 6.14】( 示 例文 件 ch06\6.14.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.o0rg/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 
<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 查 询 一 维 数组 。</h2> 
</HEAD> 
<BODY> 
<?php 
$roomtypes = array(' 单 床 房 ', ' 标 准 间 ',' 三 床 房 ', 'VIP 套房 ') ; 
$prices per day = 
array (' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
if (in_array(' 单 床 房 ', $roomtypes)){ 
echo ' 单 床 房 元 素 在 数组 $roomtypes 中 。<br />'; 
:i 
if(array key exists( ' 单 床 房 '， $prices per day)){ 


UE 4 
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echo ' 键 名 为 单 床 房 的 元 素 在 数组 $prices_per day 中 。<br />'; 
if(array search(268,$prices per day)){ 

echo ' 值 为 268 的 元 素 在 数组 Sprices_per _ day 中 。<br />'; 
. 
$prices per day keys = array keys($prices per day); 
print r($prices per day keys); 
$prices per day values = array values ($prices per day); 
print rl($prices per day values); 
?> 
</BODY> 
</HTML> 


运行 结果 如 图 6-15 所 示 。 


万 httpi//localhost PD * BO X | Blocalhost x Im 
文件 (F) ” 编 编 (E) ” 音 看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 
查询 一 维 数组 。 


单 床 房 元 素 在 数组 roomtypes 中 。 
键 名 为 单 床 房 的 元 素 在 数组 gprices_per_day 中 。 
值 为 268 的 元 素 在 数组 gprices_per_day 中 。 
Array ( [0] =》 单 床 房 [1] => 标准 间 [2] => 三 床 房 D3] =》 VIP 套 房 ) 
Array ( [0] => 298 [1] => 268 [2] => 198 [3] => 368 ) 


成 100% ~ 


图 6-15 ”查询 数字 索引 数组 和 联合 索引 数组 


案例 分 析 : 

(1) 数组 Sroomtypes 为 一 个 数字 索引 数组 。in_array(“ 单 床 房 `,$roomtypes) 判 定 元 素 ' 单 床 
房 ' 是 否 在 数组 Sroomtypes 中 ， 如 果 在 ， 则 返回 true。 站 语句 返回 值 为 真 ， 便 打印 结果 。 

(2) 数组 Sprices_per_day 为 一 个 联合 索引 数组 。array_key_exists(“ 单 床 房 ',$prices_per_day) 
判定 一 个 键 值 为 单 床 房 * 的 元 素 是 否 在 数组 $prices_per_day 中 ， 如 果 在 ， 则 返回 true。if 语句 
得 到 返回 值 为 真 ， 便 打印 结果 。array_key_exists0 是 专门 针对 联合 数组 的 “ 键 名 ”进行 查询 的 
函数 。 

(3) array_search0) 是 专门 针对 联合 数组 的 “元 素 值 ” 进 行 查询 的 函数 。 同 样 针对 数组 
Sprices_per_day 这 个 联合 数组 。array_search(268.$prices_per_day) 判 定 一 个 元 素 值 为 268 的 元 
素 是 否 在 数组 $prices_per_day 中， 如果 在 ， 则 返回 tue。 让 语句 返回 值 为 真 ， 便 打印 结果 。 

(4) 函数 array_keys0 取 得 数组 的 “ 键 值 ”， 并 把 键 值 作为 数组 元 素 输出 为 一 个 数字 索引 
数组 ， 主 要 用 于 联合 索引 数组 。array_keys($prices_per_day) 获 得 数组 Sprices_per_day 的 键 值 ， 
并 把 它 赋值 给 变量 $prices_per_day keys。 用 print 10 打印 结果 。 函 数 array_keys0 虽 然 也 可 以 
取得 数字 索引 数组 的 数字 索引 ， 但 是 这 样 意义 不 大 。 

(5) 函数 array_values0 取 得 数组 元 素 的 “元 素 值 ”， 并 把 元 素 值 作为 数组 元 素 输出 为 一 
个 数字 索引 数组 。array_values($prices_per_day) 获 得 数组 $prices_per_day 的 元 素 值 ， 并 把 它 赋 
值 给 变量 $prices_per_day_values。 用 print_r0 打 印 结果 。 


加 


这 几 个 函数 只 是 针对 一 维 数组 ， 无 法 用 于 多 维 数组 ;它们 在 查询 多 维 数组 的 时 候 ， 会 只 
处 理 最 外 围 的 数组 ， 其 他 内 嵌 的 数组 都 作为 数组 元 素 处 理 ， 不 会 得 到 内 嵌 数 组 内 的 键 值 和 元 
素 值 。 


淳 洋 直 9 小 息 


6.9 ”统计 数组 元 素 的 个 数 


使 用 count(O) 函 数 统计 数组 元 素 的 个 数 。 
下 面 的 例子 介绍 如 何 用 count0 函 数 来 统计 数组 元 素 的 个 数 。 
【 例 6.15】( 示 例文 件 ch06\6.15.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0org/TR/xhtml1/DTD/xhtmll-transitional.dtd"> 

<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 

<HEAD> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<h2> 用 count 函数 统计 数组 元 素 个 数 。</h2> 

</HEAD> 

<BODY> 

<?php 


GG 


$prices per day = 
array (' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
$roomtypesinfo = array (array('type'=>' 单 床 房 '， 
"info'=>' 此 房间 为 单 人 单间 。'， 
'price per day'=>298 
), 
array ('type'=>' 标 准 间 '， 
'info'=>' 此 房间 为 两 床 标准 配置 。'， 
'price per day'=>268 
)， 
array ('type'=>' 三 床 房 '， 
"info'=>" 此 房间 备 有 三 张 床 '， 
"Price_per_day'=>198 
)， 
array('type'=>'VIP 套房 '， 
"info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
"price per day'=>368 
); 
echo count ($prices_per_day) . ' 个 元 素 在 数组 $sprices_per_day 中 。<br />'; 
echo count ($roomtypesinfo) . ' 个 内 嵌 数 组 在 二 维 数组 Sroomtypesinfo 中 。<br />'; 
echo count ($Sroomtypesinfo,1) - ' 个 元 素 $Sroomtypesinfo 中 。<br />'; 
党 过 
</BODY> 
</HTML> 


121 $ 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 B- 


运行 结果 如 图 6-16 所 示 。 


(< 辐 碟 napylocalhos PD - BO Xlocalhost x i 


文件 (有 ”编辑 (E) ”可 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


用 count 函数 统计 数组 元 素 个 数 。 


4 个 元 素 在 数组 $prices_per_day 中 。 
4 个 内 媒 数 组 在 二 维 数 组 Jroomtypesinfo 中 。 
16 个 元 素 $roomtypesinfo 中 。 


夭 100% ~ 


6-16 用 count() 函 数 来 统计 数组 元 素 的 个 数 


案例 分 析 : 

(1) 数组 $prices_per_day 通过 countO 函 数 返 回 整数 4。 因 为 数组 $Sprices_per day 有 4 个 数 
组 元 素 。 

(2) 数组 Sroomtypesinfo 是 二 维 数组 。count($roomtypesinfo) 只 统计 了 数组 $roomtypesinfo 
内 的 4 个 内 嵌 数 组 的 数量 。 


(3) echo count($roomtypesinfo,1) 语 句 中 ，count(0) 函数 设置 了 一 个 模式 (mod) 为 整数 
“1”。 这 个 模式 (nod) 设 置 为 整数 “1” 的 意义 是 ，count 统计 的 时 候 要 对 数组 内 部 所 有 的 内 嵌 
数组 进行 循环 查询 。 所 以 最 终 的 结果 是 所 有 内 丹 数 组 的 个 数 加 上 内 扔 数组 内 元 素 的 个 数 ， 是 4 
个 内 嵌 数 组 加 上 12 个 数组 元 素 ， 为 16。 

使 用 array_count_valuesO 函 数 对 数组 内 的 元 素 值 进行 统计 ， 并 且 返 回 一 个 以 函数 值 为 “ 键 
值 ”、 以 函数 值 个 数 为 “元 素 值 ”的 数组 。 

下 面 的 例子 介绍 如 何 使 用 array_count values0O) 函 数 来 统计 数组 的 元 素 值 个 数 。 

【 例 6.16】( 示 例文 件 ch06\6.16.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<HTML xmlns="http://www.w3.org/1999/xhtm1l"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 用 array_count_values 函数 统计 数组 内 元 素 值 。</h2> 
</HEAD> 
<BODY> 
<?php 
$prices per day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198， 
' 四 床 房 '=> 198, 'VIP 套房 '=> 368); 
print rl(array count values ($prices per day)); 
全 天 
</BODY> 
</HTML> 


运行 结果 如 图 6-17 所 示 。 
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Ss 起 hapyloclhot P ~ SC X|@ localhost x I 
文件 (月 。 编 埋 (E) ”可 看 (V) 收 营 夫 (A) 工具 (T) 帮助 (H) 


用 array_count_values 函 数 统计 数组 内 元 素 值 。 


Array ( [298] => 1 [268] => 1 [198] => 2 [368] => 1 ) 


6-17 使 用 array_count_values() 函 数 来 统计 数组 的 元 素 值 个 数 


案例 分 析 : 

(1) 数组 Sprices_per day 为 一 个 联合 数组 ， 通 过 array_count_values($prices_per_day) 统 计 
数组 内 元 素 值 的 个 数 和 分 布 ， 然 后 以 ( 键 值 和 值 ) 的 形式 返回 出 一 个 数组 。 元 素 值 为 198 的 元 素 
有 两 个 ， 虽 然 它 们 的 键 值 完全 不 同 。 

(2) array_count_values0 〇 只 能 用 于 一 维 数组 ， 因 为 它 不 能 把 内 由 的 数组 当 作 元 素来 统计 。 


6.10 ”删除 数组 中 重复 的 元 素 


使 用 array_unique(O) 函 数 可 实现 数组 中 元 素 的 唯一 性 ， 也 就 是 去 掉 数 组 中 重复 的 元 素 。 不 
管 是 数字 索引 数组 还 是 联合 索引 数组 ， 都 是 以 元 素 值 为 准 。array_unique( 函 数 返回 具有 唯一 
性 元 素 值 的 数组 。 

下 面 的 例子 介绍 如 何 用 array_unique0 函 数 去 掉 数组 中 重复 的 元 素 。 

【 例 6.17】( 示 例文 件 ch06\6.17.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1l/DTD/xhtmll-transitional.dtd"> 


<HTML xmlns="http://www.w3.0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 用 array_unique 函数 清除 数组 内 的 重复 元 素 值 。</h2> 
</HEAD> 
<BODY> 
<?php 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198， 
' 四 床 房 '=> 198, 'VIP 套房 '=> 368); 
$prices_per_day2 = array(' 单 床 房 '=> 298,' 标 准 间 '=> 268, ' 四 床 房 '=> 198， 
' 三 床 房 '=> 198, 'VIP 套房 '=> 368); 
print rl(array unique($prices per day)); 
print rl(array unique($prices Per day2)); 
人 
</BODY> 
</HTML> 


i123@ 


PHP+ MySQL 动 态 网 站 开发 
案例 课堂 > 


运行 结果 如 图 6-18 所 示 。 


[¢ 问 Bhtp/Nocalhost P - BO x||@ localhost x| mx 


文件 (月 ”入 独 (E) ”过 看 (V) 收 襄 夫 (A) ”工具 (]) 帮助 (H) 


用 array_unique 函 数 清除 数组 内 的 重复 元 素 值 。 


Array ( [ 单 床 房 ] => 298 [标准 间 ] =》268 [三 床 房 ] => 198 [VIP 套房 ] => 368 ) 
Array ( [ 单 床 房 ] => 298 [标准 间 ] =》268 [四 床 房 ] => 198 [VIP 套 房 ] => 368 ) 


6-18 用 array_unique() 函 数 去 掉 数 组 中 重复 的 元 素 


案例 分 析 : 

数组 Sprices_per_day 为 一 个 联合 索引 数组 ， 通 过 array_unique($prices_per_day) 去 除 重复 的 
元 素 值 。array_unique0) 函 数 去 除 重复 的 值 是 去 除 第 二 个 出 现 的 相同 值 。 由 于 $prices_per_day 
与 $prices_per_day2 数组 中 ， 键 值 为 “三 床 房 ” 和 键 值 为 “四 床 房 ”的 198 元 素 的 位 置 正好 相 
反 ， 所 以 对 两 次 输出 的 所 保留 的 值 也 正好 相反 。 


6.11 ”调换 数组 中 的 键 值 和 元 素 值 


使 用 array_flip0 函 数 可 以 调换 数组 中 的 键 值 和 元 素 值 。 
下 面 的 例子 介绍 如 何 用 array_flip0 函 数 调换 数组 中 的 键 值 和 元 素 值 。 
【 例 6.18】( 示 例文 件 ch06\6.18.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1l/DTD/xhtmll-transitional.dtd"> 


<HTML xmlns="http://www.w3.o0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2> 用 array_flip 函数 调换 数组 内 键 值 和 元 素 值 。</h2> 
</HEAD> 
<BODY> 
<?php 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198， 
' 四 床 房 '=> 198, 'VIP 套房 '=> 368); 
print rl(array flip($prices per day)); 
> 
</BODY> 
</HTML> 


运行 结果 如 图 6-19 所 示 。 
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在 hatpyocalhos DP- 有 cxX | 起 localhost 
文件 (P。 编 壹 (E) 。 坦 看 (V) ” 收 意 夫 (A) 工具 (T 帮助 (H) 


用 array_flip 函 数 调换 数组 内 键 值 和 元 素 值 。 


Array 〔 [298] -=> 单 床 房 [268] => 标准 间 [198] => 四 床 房 [368] => VIP 套 房 ) 


图 6-19 用 array_flip() 函 数 调换 数组 中 的 键 值 和 元 素 值 


案例 分 析 : 

数组 $prices_per day 为 一 个 联合 索引 数组 ， 通 过 array _flip($prices_per day) 调 换 联 合 索引 
数组 的 键 值 和 元 素 值 ， 并 且 进 行 返回 。 但 有 意思 的 是 ，$prices_per_day 是 一 个 拥有 重复 元 素 
值 的 数组 ， 且 这 两 个 重复 元 素 值 的 “ 键 名 ”是 不 同 的 。array_flip0 逐 个 调换 每 个 数组 元 素 的 键 
值 和 元 素 值 。 而 如 果 原 来 的 元 素 值 变 为 键 名 以 后 ， 就 有 两 个 原先 为 键 名 的 、 现 在 调换 为 元 素 
值 的 数值 与 之 对 应 。 调 换 后 ，array_flip0 等 于 对 原来 的 元 素 值 (现在 的 键 名 ) 赋 值 。 当 
array_flip0 再 次 调换 到 原来 相同 的 、 现 在 为 键 名 的 值 时 ， 相 当 于 对 同一 个 键 名 再 次 赋值 ， 则 头 
一 个 调换 时 的 赋值 将 会 被 覆盖 ， 显 示 的 是 第 二 次 的 赋值 。 


6.12 ”数组 的 序列 化 


数组 的 序列 化 (Serialize) 是 用 来 将 数组 的 数据 转换 为 字符 串 ， 以 便于 传递 和 进行 数据 库存 
储 。 而 与 之 相对 应 的 操作 就 是 反 序 列 化 (Unserialize)， 把 字符 串 数据 转换 为 数组 加 以 使 用 。 

下 面 的 例子 介绍 serialize0) 函 数 和 unserialize0 〇 函数 。 

【 例 6.19】( 示 例文 件 ch06\6.19.php) 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0org/TR/xhtml1l/DTD/xhtmll-transitional.dtd"> 

<html xmlns="http://www.w3.0rg/1999/xhtml"> 

<HEAD></HEAD> 

<BODY> 

<?php 

$arr array (' 王 小 明 '，,' 李 丽 丽 '，' 方 芳 芳 ',' 刘 小 帅 ',' 张 大 勇 ',' 张 明 明 ') ; 

$str serialize ($arr); 

echo $str."<br /><br />"; 

$new arr = unserialize ($str); 

print rl($new arr); 


2> 

</BODY> 

</HTML> 

运行 结果 如 图 6-20 所 示 。 
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【¢ Er 大 localhost x Cs 
EE IE TE EECTT 


:6; 人 :0;a:6:“ 王 小 明 *;i:1;s:6:“ 李 丽 丽 "1:2; 16: 方芳 六 "1:3;a:6:" 齐 小 帅 “i:4;a:6: 张 
大 勇 “21:5;s:6:“ 张 明明 ”:] 


Array〈 [0] => 王小明 [1] =》 李 丽 丽 [2] =》 方芳 芳 [3] => 刘 小 帅 [4] => 张大 勇 [5] => 
张 明 明 ) 


图 6-20 使 用 serialize() 函 数 和 unserialize() 函 数 


案例 分 析 : 

serialize0 和 unserialize() 这 两 个 函数 的 使 用 是 比较 简单 的 ， 通 过 这 样 的 方法 对 数组 数据 进 
行 储存 和 传递 将 会 有 十 分 方便 的 效果 。 例 如 ， 可 以 直接 把 序列 化 之 后 的 数组 数据 存放 在 数据 
库 的 某 个 字段 中 ， 在 使 用 时 再 通过 反 序列 化 进行 处 理 。 


6.13 疑难 解 惑 


疑问 1: 数组 的 合并 与 联合 有 何 区 别 ? 

对 数组 的 合并 使 用 array_merge0 函 数 。 两 个 数组 的 元 素 会 合并 为 一 个 数组 的 元 素 。 而 数 
组 的 联合 ， 是 指 两 个 一 维 数 组 ， 一 个 作为 关键 字 ， 一 个 作为 数组 元 素 值 ， 联 合成 为 一 个 新 的 
联合 索引 数组 。 

疑问 2: 如 何 快速 清空 数组 ? 

在 PHP 中， 快速 清空 数组 的 方法 如 下 : 


arr = array() / /理解 为 重新 给 变量 付 一 个 空 的 数组 
unset ($arr) // 这 才 是 真正 意义 上 的 释放 ， 将 资源 完全 释放 


当 PH 
编码 错误 ); 
误 输 出 而 导致 的 错误 ; 
述 错误 处 理 和 异常 处 理 。 


P 代码 运行 时 ， 会 发 生 各 种 错误 : 可 能 是 语法 错误 (通常 是 程序 员 造 成 的 
可 能 是 缺少 功能 (由 于 浏览 器 差异 ); 可 能 是 由 于 来 自 服务 器 或 用 户 的 错 
当然 ， 也 可 能 是 由 于 许多 其 他 不 可 预知 的 因素 。 本 章 主要 讲 
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7.1 常见 的 错误 和 异常 


错误 和 异常 是 编程 中 经 常 出 现 的 问题 。 本 节 将 主要 介绍 常见 的 错误 和 异常 。 
1. 拼写 错误 


拼写 代码 时 要 求 程序 员 非 常 仔细 ， 并 且 对 编写 完成 的 代码 还 需要 认真 地 去 检查 ， 否 则 会 
出 现 不 少 编写 上 的 错误 。 

另外 ，PHP 中 常量 和 变量 都 是 区 分 大 小 写 的 ， 例 如 把 变量 名 abc 写成 ABC， 就 会 出 现 语 
法 错误 。PHP 中 的 函数 名 、 方 法 名 、 类 名 不 区 分 大 小 写 ， 但 建议 使 用 与 定义 时 相同 的 名 字 。 
魔术 常量 不 区 分 大 小 写 ， 但 是 建议 全 部 大 写 ， 包 括 _LINE 、_FILE 、_DIR 、 
_FUNCTION 、 _CLASS 、 METHOD 、 NAMESPACE 。 知 道 了 这 些 规则 ， 程 序 
员 就 可 以 避免 大 小 写 的 错误 。 

另外 ， 编 写 代 码 有 时 需要 输入 中 文字 符 ， 编 程 人 员 容易 在 输 完 中 文字 符 后 忘记 切换 输入 
法 ， 从 而 导致 输入 的 小 括号 、 分 号 或 者 引号 等 出 现 错误 ， 当 然 ， 这 种 错误 输入 在 大 多 数 编程 
软件 中 显示 的 颜色 会 跟 正确 的 输入 显示 的 颜色 不 一 样 ， 较 容易 发 现 ， 但 还 是 应 该 细心 谨慎 ， 
来 减少 错误 的 出 现 。 


2. 单 引号 和 双 引 号 的 混乱 


单 引号 、 双 引号 在 PHP 中 没有 特殊 的 区 别 ， 都 可 以 用 来 创建 字符 串 。 但 是 必须 使 用 同一 
种 单 或 双 引 号 来 定义 字符 串 ， 例 如 ，'*Hello" 和 “Hello 为 非法 的 字符 串 定义 。 单 引号 串 和 双 引 
号 串 在 PHP 中 的 处 理 是 不 同 的 。 双 引号 串 中 的 内 容 可 以 被 解释 而 且 蔡 换 ， 而 单 引 号 串 中 的 内 
容 总 被 认为 是 普通 字符 。 

另外 ， 缺 少 单 引号 或 者 双 引 号 也 是 经 常 出 现 的 问题 。 例 如 : 

echo "错误 处 理 的 方法 ; 


其 中 缺少 了 一 个 双 引 号 ， 运 行 时 会 提示 错误 。 
3. 括号 使 用 混乱 


首先 需要 说 明 的 是 ， 在 PHP 中 ， 括 号 包含 两 种 语义 ， 可 以 是 分 隔 符 ， 也 可 以 是 表达 式 。 
例如 : 

(1) 作为 分 隔 符 比较 常用 ， 比 如 (1+4)*4 等 于 20。 

(2) 在 (function0f))0: 中 ， 最 后 面 的 括号 表示 立即 执行 这 个 方法 。 

由 于 括号 的 使 用 层次 比较 多 ， 所 以 可 能 会 导致 括号 不 匹配 的 错误 。 

例如 以 下 代码 : 


if((($a==$b)and ($b==$c))and ($c==$qd) { // 此 处 缺少 一 个 括号 
echo "正确 的 括号 使 用 方法 ! " 
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4. 等 号 与 赋值 混淆 
等 号 与 赋值 符号 混淆 的 这 种 错误 一 般 较 常 出 现在 站 语句 中 ， 而 且 这 种 错误 在 PHP 中 不 会 
产生 错误 信息 ， 所 以 在 查找 错误 时 往往 不 容易 被 发 现 。 例 如 : 


a 
echo ("没有 找到 相关 信息 ") ; 


上 面 的 代码 在 逻辑 上 是 没有 问题 的 ， 它 的 运行 结果 是 将 1 赋值 给 了 s， 成 功 后 则 弹出 对 话 
框 ， 而 不 是 对 s 和 1 进行 比较 ， 这 不 符合 开发 者 的 本 意 。 正 确 写法 是 s==1， 而 不 是 s=1。 

5. 缺少 美元 符号 

在 PHP 中 ， 设 置 变量 时 需要 使 用 美元 符号 “$”， 如 果 不 添加 美元 符号 ， 就 会 引起 解析 
错误 。 

例如 以 下 代码 : 


for($s=1; $s<=10; st++){ // 缺 少 一 个 变量 的 美元 符号 
echo (" 缺 少 美元 符号 ! ") ; 
} 


需要 修改 s++ 为 $s+t+。 如 果 $s<=10: 缺 少 美元 符号 ， 则 会 进入 无 限 循环 状态 。 

6. 调用 不 存在 的 常量 和 变量 

如 果 调 用 没有 声明 的 常量 或 者 变量 ， 将 会 触发 NOTICE 错误 。 例 如 下 面 的 代码 中 ， 输 出 
时 错误 书写 了 变量 的 名 称 : 


<?php 
$abab = "错误 处 理 的 方法 " 
echo $abba; // 调 用 了 不 存在 的 变量 


> 


如 果 运 行程 序 ， 会 提示 如 图 7-1 所 示 的 错误 。 
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7. 调用 不 存在 的 文件 
如 果 调 用 不 存在 的 文件 ， 程 序 将 会 停止 运行 。 例 如 下 面 的 代码 : 


<?php 
include ("mybook.txt"); // 调 用 了 一 个 不 存在 的 文件 


2> 


运行 后 ， 将 会 弹出 如 图 7-2 所 示 的 错误 提示 信息 。 


【¢ 疾 @ hip/oc B P- cx| localhost x I 


文件 (F) ”编辑 (E) 。 坦 看 (V) 收藏 只 (A)】 工具 (T) 。 帮助 (H) 


Function Location 


137512 fnain} ( ) .php:0 


图 7-2 调用 了 不 存在 的 文件 
8. 环境 配置 的 错误 


如 果 环 境 配置 不 当 ， 也 会 给 运行 带 来 错误 ， 例 如 操作 系统 、PHP 配置 文件 和 PHP 的 版 本 
等 ， 这 些 如 果 配 置 不 正确 ， 将 会 提示 文件 无 法 打开 、 操 作 权限 不 具备 和 服务 器 无 法 连接 等 错 
误 信息 。 

首先 ， 不 同 的 操作 系统 采用 不 同 的 路 径 格式 ， 这 些 都 会 导致 程序 运行 错误 。 此 外 ，PHP 
在 不 同 的 操作 系统 上 的 功能 也 会 有 差异 ， 数 据 库 的 运行 也 会 在 不 同 的 操作 系统 中 有 问题 出 现 
等 。 另 外 ，PHP 的 配置 也 很 重要 ， 由 于 各 个 计算 机 的 配置 方法 不 尽 相 同 ， 当 程序 的 运行 环境 
发 生变 化 时 ， 也 会 出 现 这 样 或 者 那样 的 问题 。 最 后 ， 是 PHP 的 版 本 问题 ，PHP 的 高 版 本 在 一 
定 程度 上 可 以 兼容 低 版 本 ， 但 是 针对 高 版 本 编写 的 程序 拿 到 低 版 本 中 运行 时 ， 会 出 现 意 想 不 
到 的 问题 ， 这 些 都 是 有 关 环 境 配置 的 不 同 而 引起 的 错误 。 


9. 数据 库 服务 器 连接 错误 


由 于 PHP 应 用 于 动态 网 站 的 开发 ， 所 以 经 常会 对 数据 库 进行 基本 的 操作 ， 在 操作 数据 库 
之 前 ， 需 要 连接 数据 库 服 务 ， 如 果 用 户 名 或 者 密码 设置 不 正确 ， 或 者 数据 库 不 存在 ， 或 者 数 
据 库 的 属性 不 允许 访问 等 ， 都 会 在 程序 运行 中 出 现 错误 。 

例如 以 下 的 代码 ， 在 连接 数据 库 的 过 程 中 ， 密 码 编写 是 错误 的 : 


<?php 
$conn = mysql connect ("localhost","root","root"); // 连 接 MysQL 服务 器 


第 
运行 后 ， 将 会 弹出 如 图 7-3 所 示 的 错误 提示 信息 。 了 
seoc Bp- GX locahost 本 
ET] 处 
理 
[2 

， 
元 
Call Stack 常 
# Time Memory Function Location 处 
1| 0.0006 138016 | ainj( ) [ALphps0 理 

2 0.0006 158488mwsoj comect () [ALphp:2 


到 100% 


图 7-3 无 法 连接 数据 库 
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见 的 错误 处 理 方法 包括 使 用 错误 处 理 机 制 ， 使 用 DIE 语句 调试 、 自 定义 错误 和 错误 触 
发 器 等 。 本 节 将 会 讲述 如 何 处 理 程序 中 的 错误 。 
7.2.1 php.ini 中 的 错误 处 理 机 制 


在 前 面 的 例子 中 ， 错 误 提示 会 显示 错误 的 信息 、 错 误 文件 的 行 号 信息 等 ， 这 是 PHP 最 基 
本 的 错误 报告 机 制 。 此 外 ，php.ini 文件 规定 了 错误 的 显示 方式 ， 包 括 配 置 选项 的 名 称 、 默 认 
值 和 表述 的 含义 等 。 常 见 的 错误 配置 选项 的 内 容 如 表 7-1 所 示 。 


表 7-1 常见 的 php.ini 文件 中 控制 错误 显示 的 配置 选项 含义 


IGG 


名 称 默认 值 含义 
i DE ta hi PHP 的 一 部 分 输出 。 的 
到 设置 ， 但 是 为 了 安全 考虑 ， 在 生产 环境 中 还 是 设置 为 Off 比较 好 
这 个 设置 会 显示 所 有 的 出 错 信息 。 这 种 设置 会 让 一 些 无 害 的 提示 也 
error_ reporting E all 会 显示 ， 所 以 可 以 设置 error_reporting 的 默认 值 : error_reporting = 
E ALL & ~E NOTICE， 这 样 只 会 显示 错误 和 不 良 编码 
本 设置 记录 错误 日 志 的 文件 。 默 认 情 况 下 将 错误 发 送 到 Web 服务 器 
加 日 志 ， 用 户 也 可 以 指定 写 入 的 文件 
html_errors On 控制 是 否 在 错误 信息 中 采用 HTML 格式 
log errors OfF 控制 是 否 应 该 将 错误 发 送 到 主机 服务 器 的 日 志文 件 
display_startup errors | Off 控制 是 否 显示 PHP 启动 时 的 错误 
track errors Off 设置 是 否 保 存 最 近 一 个 警告 或 错误 信息 
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7.2.2 应 用 DIE 语句 来 调试 


使 用 DIE 语句 进行 调试 的 优势 是 ， 不 仅 可 以 显示 错误 的 位 置 ， 还 可 以 输出 错误 信息 。 一 
且 出 现 错误 ， 程 序 将 会 终止 运行 ， 并 在 浏览 器 上 显示 出 错 之 前 的 信息 和 错误 信息 。 

前 面 曾经 讲述 过 ， 调 用 不 存在 的 文件 会 提示 错误 信息 ， 如 果 运 用 DIE 来 调试 ， 将 会 输出 
自 定义 的 错误 信息 。 

【 例 7.1】( 示 例文 件 ch07\7.1.php) 


<html> 

<head> 

<title> DIE 语句 调试 </title> 

</head> 

<body> 

<?php 

if(!file exists("welcome.txt")){ 
die ("文件 不 存在 ") ; 

}else{ 
$file = fopen("welcome.txt","r"); 

} 

?> 

</body> 

</html> 


运行 后 ， 结 果 如 图 7-4 所 示 。 


总 htpy/loc. 嘎 只 - BC X | 和 @ DIE 语句 调试 
文件 (F) ”编辑 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 


文件 不 存在 


7-4 应 用 DIE 语句 调试 
与 基本 的 错误 报告 机 制 相 比 ， 使 用 DIE 语句 调试 显得 更 有 效 ， 这 是 由 于 它 采用 了 一 个 简 
单 的 错误 处 理 机 制 ， 在 错误 之 后 终止 了 脚本 。 
7.2.3 自 定 义 错误 和 错误 触发 器 


简单 地 终止 脚本 并 不 总 是 恰当 的 方式 。 本 小 节 将 讲述 如 何 自 定义 错误 和 错误 触发 器 。 创 
建 一 个 自 定义 的 错误 处 理 器 非常 简单 ， 用 户 可 以 创建 一 个 专用 函数 ， 然 后 在 PHP 程序 发 生 错 
误 时 调用 该 函数 。 
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自 定义 的 错误 函数 的 语法 格式 如 下 : 

error function(error level,error message,error file,error line,error Context) 

该 函数 必须 至 少 包含 level 和 message 参数 ， 另 外 3 个 参数 fle、line-number 和 context 是 
可 选 的 。 各 个 参数 的 具体 含义 如 表 7-2 所 示 。 


表 7-2 各 个 参数 的 含义 


参 数 含义 
error level 。 为 用 户 定义 的 错误 规定 错误 报告 级 别 。 必 须 是 一 个 值 
eITOT message o 为 用 户 定义 的 错误 规定 错误 消息 
error file 。 规 定 错误 在 其 中 发 生 的 文件 名 
error line 。 规 定 错误 发 生 的 行 号 
error_context 。 规 定 一 个 数组 ， 包 含 了 当 错 误 发 生 时 在 使 用 的 每 个 变量 以 及 它们 的 值 


参数 error_level 为 定义 错误 规定 的 报告 级 别 ， 这 些 错误 报告 级 别 是 错误 处 理 程序 将 要 处 
理 的 错误 的 类 型 。 具 体 的 级 别 值 和 含义 如 表 7-3 所 示 。 


数 值 常 量 

区 E WARNING 

8 E_NOTICE 

256 E_USER ERROR 
512 E_USER_WARNING 


1024 E_USER_NOTICE 


表 7-3 错误 的 级 别 值 和 含义 


含义 
非 致命 的 run-time 错误 。 不 暂停 脚本 执行 
Run-time 通知 。 脚 本 发 现 可 能 有 错误 发 生 ， 但 也 可 能 在 脚本 正常 
运行 时 发 生 
致命 的 用 户 生成 的 错误 。 类 似 于 程序 员 用 PHP 函数 trigger_error() 
设置 的 E ERROR 
非 致 命 的 用 户 生 成 的 警告 。 这 类 似 于 程序 员 使 用 PHP 函数 
trigger_error() 设 置 的 E_ WARNING 
用 户 生 成 的 通知 。 这 类 似 于 程序 员 使 用 PHP 函数 trigger_error() 设 
置 的 E NOTICE 


4096 E_RECOVERABLE ERROR 


8191 E_ALL 


可 捕获 的 致命 错误 。 类似 E_ ERROR， 但 可 被 用 户 定义 的 处 理 程序 
捕获 
所 有 错误 和 警告 


下 面 通过 例子 来 讲解 如 何 自 定义 错误 和 错误 触发 器 。 
首先 创建 一 个 处 理 错误 的 函数 : 


function customError ($errno, $errstr) 


1 


echo "<b> 错 误 :</b> [$errno] Serrstr<br />"; 


echo "终止 程序 "; 
die(); 


到 
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上 面 的 代码 是 一 个 简单 的 错误 处 理 函 数 。 当 它 被 触发 时 ， 它 会 取得 错误 级 别 和 错误 消 
息 。 然 后 它 会 输出 错误 级 别 和 消息 ， 并 终止 程序 。 

创建 了 一 个 错误 处 理 函 数 后 ， 下 面 需要 确定 在 何 时 触发 该 函数 。 在 PHP 中 ， 使 用 
set_error_handler0 函 数 来 设置 用 户 自 定义 的 错误 处 理 函 数 。 该 函数 用 于 创建 运行 期 间 的 用 户 自 
己 的 错误 处 理 方法 。 该 函数 会 返回 旧 的 错误 处 理 程序 ， 若 失败 ， 则 返回 null。 具 体 的 语法 格 
式 如 下 : 


set_error handler (error function, error types) 


其 中 ，error_function 为 必需 参数 ， 规 定 发 生 错误 时 运行 的 函数 ; error types 是 可 选 参 
如 果 不 选 择 此 参数 ， 则 表示 默认 值 为 “E ALL”。 
在 本 例 中 ， 针 对 所 有 错误 来 使 用 自 定义 错误 处 理 程序 ， 具 体 的 代码 如 下 : 


set_error handler("customError"); 


下 面 通过 尝试 输出 不 存在 的 变量 ， 来 测试 这 个 错误 处 理 程序 。 
【 例 7.2】( 示 例文 件 ch07\7.2.php) 


<html> 
<head> 
<title> 自 定义 错误 </title> 
</head> 
<body> 
<?php 
// 定 义 错误 函数 
function customError ($errno, $errstr){ 
echo "<b> 错 误 :</b> [$errno] $errstr"; 


溢 


} 
// 设 置 错误 函数 的 处 理 
set_error handler ("customError"); 
// 触 发 自 定义 错误 函数 
echol($test); 

> 

</body> 

</html> 


运行 后 ， 结 果 如 图 7-5 所 示 。 


Bhtpi/loc. B PD- BCx|GeaR | 
文件 (月 ”编辑 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


错误 : [8] Undefined variable: test 


图 7-5 自 定义 错误 
在 脚本 中 用 户 输入 数据 的 位 置 设置 当 用 户 的 输入 无 效 时 触发 错误 的 很 有 用 的 。 在 PHP 


篇 
a 


中 ， 这 个 任务 由 trigger_error(0) 来 完成 。trigger_error0) 函 数 创建 用 户 定义 的 错误 消息 。 
trigger_error0) 用 于 在 用 户 指定 的 条 件 下 触发 一 个 错误 消息 。 它 与 内 建 的 错误 处 理 器 一 同 
使 用 ， 也 可 以 与 由 set_error handler0 函 数 创 建 的 用 户 自 定义 函数 一 起 使 用 。 如 果 指 定 了 一 个 
不 合法 的 错误 类 型 ， 该 函数 返回 false， 否 则 返回 true。 
trigger_error0 函 数 的 具体 语法 格式 如 下 : 


trigger error(error message, error types) 


其 中 error_message 为 必需 参数 ， 规 定 错误 消息 ， 长 度 限 制 为 1024 个 字符 ，error_types 为 
可 选 参数 ， 规 定 错误 消息 的 错误 类 型 ， 可 能 的 值 为 E USER ERROR、E USER WARNING 
或 者 E USER NOTICE。 

【 例 7.3】( 示 例文 件 ch07\7.3.php) 


<html> 
<head> 
<title> trigger error() 函数 </title> 
</head> 
<body> 
<?php 
$test = 5; 
if ($test > 4){ 
trigger error("Value must be 4 or below"); 
} 
县 学 
</body> 
</html> 


运行 后 ， 结 果 如 图 7-6 所 示 。 由 于 test 数值 为 5， 发 生 了 E_USER_WARNING 错误 。 
| 二 一 | 


Bhtpilloc. B Pp BOX| Brooererooms x | IIS 
文件 MWR) EV tm) ITRm fi | 


滑 订 下 各 闪 月 新 和 蓝 由 /小 


多 A 


(CD 


人 TCR Time Menory Function Location 
1 0.0006 | 158424 inain] ( ) 9. 3. php:0 
2 0.0006 | 13890dltrigger errcr ( ) .NA9.3.php:10 


到 100% ~ 


图 7-6 使 用 trigger_error() 函 数 
下 面 通过 示例 来 讲述 trigger_errorO 函 数 和 自 定义 函数 一 起 使 用 的 处 理 方法 。 
【 例 7.4】( 示 例文 件 ch07\7.4.php) 


<html> 
<head> 
<title> 自 定义 函数 和 trigger_error () 函数 </title> 
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</head> 
<body> 
<?php 
// 定 义 错误 函数 


function customError($errno, $errstr){ 
echo "<b> 错 误 :</b> [$errno] $errstr"; 


} 
// 设 置 错误 函数 的 处 理 
set error handler ("customError", E USER WARNING); 
// trigger error 函数 
$test = 5; 
if ($test>4){ 
trigger error("Value must be 4 or below", E USER WARNING); 


运行 后 ， 结 果 如 图 7-7 所 示 。 


【¢ 问 您 rtpyoc. B D - BO X | E sxXBwintrigger.. x 
文件 (有 编辑 () 查看 W) 收 训 天 (A)】 工具 (T) 帮助 (H) 


错误 : [512] Value must be 4 or below 


7-7 ”使 用 自 定义 函数 和 trigger_error() 函 数 


7.2.4 ”错误 记录 


默认 情况 下 ， 根 据 在 php.ini 中 的 error log 配置 ，PHP 向 服务 器 的 错误 记录 系统 或 文件 发 
送 错误 记录 。 通 过 使 用 error_ log0 函 数 ， 用 户 可 以 向 指定 的 文件 或 远程 目的 地 发 送 错误 记录 。 

通过 电子 邮件 向 用 户 自 己 发 送 错误 消息 ， 是 一 种 获得 指定 错误 的 通知 的 好 办 法 。 下 面 通 
过 示例 来 讲解 。 

【 例 7.5】( 示 例文 件 ch07\7.5.php) 

<html> 

<head> 

<title>error 1og() 函数 </title> 

</head> 

<body> 

<?php 


全 1 


// 定 义 错误 函数 

function customError($errno, $errstr){ 
echo "<b> 错 误 :</b> [$errno] Serrstr <br/>"; 
echo "错误 记录 已 经 发 送 完 毕 "; 


error 1og( "错误 : [$errno] $errstr",l1, "someone@example.com", 


"From: webmastere@example.com"); 


. 

// 设 置 错误 函数 的 处 理 

set error handler ("customError", E USER WARNING); 
//trigger error 函数 

$test = 5; 

if ($test > 4){ 


trigger error("Value must be 4 or below", E USER WARNING); 


运行 后 ， 结 果 如 图 7-8 所 示 。 在 指定 的 someone@example.com 邮箱 中 将 收 到 错误 信息 。 


ole 


@S 名 htpi//loc. 国 Dv 呈 CX| 儿 errorlog0 下 数 x 


文件 (有 ) ”编辑 (E) ”可 看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


错误 : [512] Value must be 4 or below 
错误 记录 已 经 发 送 完毕 


图 7-8 通过 E-mail 发 送 错误 信息 


7.3 异常 处 理 


异常 (Exception) 用 于 在 指定 的 错误 发 生 时 改变 脚本 的 正常 执行 流程 。 PHP 5.5 提供 了 一 种 


新 的 面向 对 象 的 错误 处 理 方法 。 本 节 主要 讲述 异常 处 理 的 方法 和 技巧 。 
7.3.1 异常 的 基本 处 理 方法 


异常 处 理 用 于 在 指定 的 错误 (异常 ) 情 况 发 生 时 改变 脚本 的 正常 执行 流程 。 当 异常 被 触发 


时 ， 通 常会 发 生 以 下 动作 。 
(1) 当前 代码 状态 被 保存 。 
(2) 代码 执行 被 切换 到 预定 义 的 异常 处 理 器 函数 。 


|] 
a 
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(3) 根据 情况 ， 处 理 器 也 许 会 从 保存 的 代码 状态 重新 开始 执行 代码 ， 终 止 脚本 执行 ， 或 
从 代码 中 另外 的 位 置 继 续 执行 脚本 。 

当 异 常 被 抛 出 时 ， 其 后 的 代码 不 会 继续 执行 ，PHP 会 尝试 查找 匹配 的 catch 代码 块 。 如 果 
异常 没有 被 捕获 ， 而 且 又 没有 使 用 set_exception handler0 做 相应 处 理 的 话 ， 那 么 将 发 生 一 个 
严重 的 错误 ， 并 且 输 出 “Uncaught Exception”( 未 捕获 异常 ) 的 错误 消息 。 

下 面 的 示例 中 抛 出 一 个 异常 ， 同 时 不 去 捕获 它 。 

【 例 7.6】( 示 例文 件 ch07\7.6.php) 


<html> 

<head> 

<title> 异 常 </title> 

</head> 

<body> 

<?php 

// 创 建 带 有 异常 的 函数 

function checkNum($number){ 
if($number>1){ 

throw new Exception("Value must be 1 or below"); 

} 


return true; 


} 

// 抛 出 异常 
checkNum(2) 7 
人 

</body> 
</html> 


运行 后 ， 结 果 如 图 7-9 所 示 。 由 于 没有 捕获 异常 ， 出 现 了 错误 提示 消息 。 


|G hloc.. BP- BOx)| Ess I 


139864 train] ( ) 看 a 
140176 checkliun( ) 3. 6. php:15 


|2| 0.0005 | 


屠 100%6 ~ 


图 7-9 没有 捕获 异常 
如 果 想 避免 出 现 上 面 例子 出 现 的 错误 ， 需 要 创建 适当 的 代码 来 处 理 异常 。 处 理 异常 的 程 
序 应 当 包 括 下 列 代码 块 。 
e@ try 代码 块 : 使 用 异常 的 函数 应 该 位 于 try 代码 块 内 。 如 果 没 有 触发 异常 ， 则 代码 将 
照常 继续 执行 。 但 是 如 果 异 常 被 触发 ， 会 抛 出 一 个 异常 。 
@ “throw 代码 块 : 这 里 规定 如 何 触发 异常 。 每 一 个 throw 必须 对 应 至 少 一 个 catch。 
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@ catch 代码 块 : catch 代码 块 会 捕获 异常 ， 并 创建 一 个 包含 异常 信息 的 对 象 。 
【 例 7.7】( 示 例文 件 ch07\7.7.php) 


<html> 
<head> 
<title> 处 理 异常 </title> 
</head> 
<body> 
<?php 
// 创 建 可 抛 出 一 个 异常 的 函数 
function checkNum($number){ 
if($number>1){ 
throw new Exception ("数值 必须 小 于 或 等 于 1"); 
i 


return true; 


} 

// 在 try 代码 块 中 触发 异常 

try{ 
checkNum(2); 
// 如 果 没 有 异常 ， 则 会 显示 以 下 信息 
echo ' 没 有 任何 异常 '; 


} 
// 捕 获 异常 
catch (Exception $e){ 
echo ' 异 常 信息 : ' .$e->getMessage(); 
} 
人 
</body> 
</html> 


运行 后 ， 结 果 如 图 7-10 所 示 。 由 于 抛 出 异常 后 捕获 了 异常 ， 所 以 出 现 了 提示 消息 。 


| 异常 信息 : 数值 必须 小 于 或 等 于 1 


7-10 捕获 了 异常 


案例 分 析 : 

(1) 创建 checkNum0) 函 数 ， 它 检测 数字 是 否 大 于 1。 如 果 是 ， 则 抛 出 一 个 异常 。 
(2) 在 try 代码 块 中 调用 checkNum() 函 数 。 

(3) checkNum() 函 数 中 的 异常 被 抛 出 。 


13@ 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 四” 


(4) catch 代码 块 接收 到 该 异常 ， 并 创建 一 个 包含 异常 信息 的 对 象 (Se)。 
(5) 通过 从 这 个 exception 对 象 调用 $e->getMessage()， 输 出 来 自 该 异常 的 错误 消息 。 


7.3.2” 自 定义 的 异常 处 理 器 


创建 自 定义 的 异常 处 理 程序 非常 简单 ， 只 需要 创建 一 个 专门 的 类 ， 当 PHP 程序 中 发 生 异 
常 时 ， 调 用 该 类 的 函数 即 可 。 当 然 ， 该 类 必须 是 exception 类 的 一 个 扩展 。 

这 个 自 定义 的 exception 类 继承 了 PHP 的 exception 类 的 所 有 属性 ， 然 后 用 户 可 向 其 添加 
自 定义 的 函数 。 

下 面 通过 例子 来 讲解 如 何 创建 自 定义 的 异常 处 理 器 。 

【 例 7.8】( 示 例文 件 ch07\7.8.php) 


<html> 

<head> 
<title> 自 定义 异常 处 理 器 </title> 
</head> 


<body> 
<?php 
class customException extends Exception{ 


public function errorMessage(){ 


// 错 误 消息 
$errorMsg = "异常 发 生 的 行 : ' . $this->getLine().' in '.$this->getFile() 
.1: <b>'.$this->getMessage() .'</b> 不 是 一 个 有 效 的 邮箱 地 址 '; 


return $errorMsg; 
} 
3 
$email = "someone@example.321lcom"; 
try 


// 检 查 是 否 符合 条 件 
if (filter var($email, FILTER VALIDATE EMAIL) === FALSE) { 
// 如 何 邮 件 地 址 无 效 ， 则 抛 出 异常 
throw new customException ($email); 
1 
} catch (customException S$Se)1{ 
// 显 示 自 定义 的 消息 


echo $e->errorMessage(); 


运行 后 结果 如 图 7-11 所 示 。 
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ET EE x 
文件 (月 ” 编 包 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


| 异常 发 生 的 行 。 21 in C:\www\php5. 5\ch09\9. 8. php: 
someone@example. 321com 不 是 一 个 有 效 的 邮箱 地 址 


图 7-11 自 定义 异常 处 理 器 


案例 分 析 : 

(1) customException0 类 是 作为 旧 的 exception 类 的 一 个 扩展 来 创建 的 ， 这 样 它 就 继承 了 
旧 类 的 所 有 属性 和 方法 。 

(2) 创建 errorMessage0 函 数 ， 如 果 E-mail 地 址 不 合法 ， 则 该 函数 返回 一 条 错误 消息 

(3) 把 Semail 变量 设置 为 不 合法 的 E-mail 地 址 字符 串 。 

(4) 执行 try 代码 块 ， 由 于 E-mail 地 址 不 合法 ， 因 此 抛 出 一 个 异常 。 

(5) catch 代码 块 捕获 异常 ， 并 显示 错误 消息 。 


7.3.3 ”处 理 多 个 异常 


在 上 面 的 案例 中 ， 只 是 检查 了 邮箱 地 址 是 否 有 效 。 如 果 用 户 想 检查 邮箱 是 否 为 雅虎 邮 
箱 ， 或 想 检 查 邮 箱 是 否 有 效 等 ， 这 就 出 现 了 多 个 可 能 发 生 异 常 的 情况 。 用 户 可 以 使 用 多 个 
让 ...else 代码 块 ， 或 一 个 switch 代码 块 ， 或 者 嵌 套 多 个 异常 。 这 些 异常 能 够 使 用 不 同 的 
exception 类 ， 并 返回 不 同 的 错误 消息 。 

【 例 7.9】( 示 例文 件 ch07\7.9.php) 


<html> 
<head> 
<title> 自 定义 异常 处 理 器 </title> 
</head> 
<body> 
<?php 
class customException extends Exception{ 
public function errorMessage(){ 
// 定 义 错误 信息 
$errorMsg = ' 错 误 消息 的 行 : ' .$this->getLine().' in '.$this->getFile() 
.': <b>'.$this->getMessage() .'</b> 不 是 一 个 有 效 的 邮箱 地 址 ' ; 
return $errorMsg; 
I 


$email = "someone@yahoo.com"; 
tryt{ 
// 检 查 是 否 符合 条 件 
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if(filter var($email, FILTER VALIDATE EMAIL) === FALSE) 
€ 
// 如 果 邮 箱 地 址 无 效 ， 则 抛 出 异常 


throw new customException($email); 


} 
// 检 查 邮箱 是 否 是 雅虎 邮箱 
if(strpos($email, "yahoo") !== FALSE){ 
throw new Exception ("$email 是 一 个 雅虎 邮箱 ") ; 
} 
} catch (customException S$e) { 
echo $e->errorMessage(); 
} catch (Exception $e) { 
echo $e->getMessage(); 


} 


> 


</body> 
</html> 
运行 后 ， 结 果 如 图 7-12 所 示 。 上 面 的 代码 测试 了 两 种 条 件 ， 如 果 任 何 条 件 都 不 成 立 ， 则 
抛 出 一 个 异常 。 
【¢ [Er BB 1- BOX|Ges 人 ss 
文件 (F) 。 编 句 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 
someone@yahoo. com 是 一 个 雅虎 邮箱 
图 7-12 处理 多 个 异常 
案例 分 析 : 
(1) customException0) 类 是 作为 旧 的 exception 类 的 一 个 扩展 来 创建 的 ， 这 样 它 就 继承 了 
旧 类 的 所 有 属性 和 方法 。 


(2) 创建 errorMessage() 函 数 。 如 果 E-mail 地 址 不 合法 ， 则 该 函数 返回 一 个 错误 消息 。 
(3) 执行 try 代码 块 ， 在 第 一 个 条 件 下 ， 不 会 抛 出 异常 。 

(4) 由 于 E-mail 含有 字符 串 “yahoo”"， 第 二 个 条 件 会 触发 异常 。 

(5) catch 代码 块 会 捕获 异常 ， 并 显示 恰当 的 错误 消息 。 


7.3.4 设置 顶层 异常 处 理 器 


所 有 未 捕获 的 异常 ， 都 可 以 通过 顶层 异常 处 理 器 来 处 理 。 顶 层 异 常 处 理 器 可 以 使 用 set_ 
exception handler() 函 数 来 实现 。 
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set_exception_ handlerO 函 数 设 置 用 户 自 定义 的 异常 处 理 函 数 。 该 函数 用 于 创建 运行 时 期 间 
的 用 户 自己 的 异常 处 理 方法 。 该 函数 会 返回 旧 的 异常 处 理 程序 ， 若 失败 ， 则 返回 null。 具 体 
的 语法 格式 如 下 : 


set exception handler (exception function) 


其 中 exception function 参数 为 必需 的 参数 ， 规 定 未 捕获 的 异常 发 生 时 调用 的 函数 ， 该 函 
数 必须 在 调用 set_exception handler0 函 数 之 前 定义 。 这 个 异常 处 理 函 数 需 要 一 个 参数 ， 即 抛 
出 的 exception 对 象 。 

【 例 7.10】( 示 例文 件 ch07\7.10.php) 


<html> 
<head> 
<title> 顶 层 异 常 处 理 器 </title> 
</head> 
<body> 
<?php 
function myException ($exception){ 
echo "<b> 异 常 是 :</b> " :+ $exception->getMessage(); 
} 
set exception handler('myException'); 
throw new Exception(' 正 在 处 理 未 被 捕获 的 异常 ') ; 
学 之 
</body> 
</html> 


运行 后 ， 结 果 如 图 7-13 所 示 。 上 面 的 代码 不 存在 catch 代码 块 ， 而 是 触发 顶层 的 异常 处 
理 程序 。 用 户 应 该 使 用 此 函数 来 捕获 所 有 未 被 捕获 的 异常 。 


碟 htpyioc- 四 PP-8cx| 等 
文件 (有 篇 器 (E) 查看 V) 收 项 夫 (A) 工具 (T) 帮助 (H) 


异常 是 : 正在 处 理 未 被 捕获 的 异常 


7-13 ”使 用 项 层 异常 处 理 器 


7.4 ”实战 演练 一 一 处 理 异常 或 错误 


错误 处 理 也 叫 异 常 处 理 。 通 过 使 用 ty...throw...catch 结构 和 一 个 内 置 函数 Exception() 来 
“ 抛 出 ”和 “处 理 ” 错 误 或 异常 。 
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下 面 通过 打开 文件 的 例子 来 介绍 异常 的 处 理 方法 和 技巧 。 
【 例 7.11】( 示 例文 件 ch07\7.11.php) 


<html> 
<head> 
<title> 处 理 异常 或 错误 </title> 
</head> 
<body> 
<?php 
$DOCUMENT ROOT = $_ SERVER['DOCUMENT ROOT']; 
@$fp = fopen("$DOCUMENT ROOT/book.txt",'rb'); 
tryt{ 

if (!$fp){ 

throw new Exception ("文件 路 径 有 误 或 找 不 到 文件 。") ; 

} 
}catch (Exception $exception){ 

echo $exception->getMessage(); 

echo "在 文件 ". $exception->getFile() 

." 的 " .$exception->getLine()." 行 。<br />"; 


3 

@fclose ($fp); 
?> 

</body> 
</html> 


运行 结果 如 图 7-14 所 示 。 


Bhp/loc. B PD- aox|G unseen 
文件 编 甸 (E)】 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


| 文件 路 径 有 误 或 找 不 到 文件 。 在 文件 
| C:\www\php5. 5\ch09\9. 11. php 的 11 行 。 


7-14 “处理 异常 或 错误 


案例 分 析 : 

(1) fopen0 函 数 打 开 “$SDOCUMENT_ROOT/book.txt” 文 件 进行 读 取 ， 但 是 由 于 book.txt 
文件 不 存在 ， 所 以 $fp 为 false。 

(2) try 区 块 判 断 $fpp 为 false 时 ， 抛 出 一 个 异常 ， 此 异常 直接 通过 new 关键 字 生成 
了 Exception0) 类 的 实例 。 异 常 信息 是 传 入 参数 定义 的 “文件 路 径 有 误 或 找 不 到 文件 。”。 

(3) catch 区 块 通过 处 理 传 入 的 Exception0) 类 实例 ， 显 示 出 错误 信息 、 错 误 文件 、 错 误 发 
生 的 行 号 。 这 些 是 通过 直接 调用 Exception0 类 实例 Sexception 的 内 置 类 方法 获得 的 。 错 误 信 息 
由 getMessage0 生 成 ， 错 误 文 件 由 getFile0 生 成 ， 错 误 发 生 行 号 由 getLine0 生 成 。 


o 


(4) @fclose0 和 @S$fp= fopen0 中 的 “@” 表 示 屏 蔽 此 命令 执行 中 产生 的 错误 信息 。 


7.5 疑难 解 惑 


疑问 1: 处 理 异常 有 什么 规则 ? 


在 处 理 异 常 时 ， 有 下 列 规则 需要 用 户 牢 牢 掌握 : 

e@ ”需要 进行 异常 处 理 的 代码 应 该 放 入 try 代码 块 内 ， 以 便 捕获 潜在 的 异常 。 
e@ 每 个 try 或 throw 代码 块 必须 至 少 拥有 一 个 对 应 的 catch 代码 块 。 

e@ ”使 用 多 个 catch 代码 块 可 以 捕获 不 同 种 类 的 异常 。 

@ 可 以 在 try 代码 块 内 的 catch 代码 块 中 再 次 抛 出 (re-thrown) 异 常 。 


疑问 2: 如 何 隐藏 错误 信息 ? 


PHP 提供 了 一 种 隐藏 错误 的 方法 。 就 是 在 被 调用 的 函数 名 前 加 @ 符 号 ， 这 样 会 隐藏 可 能 
由 于 这 个 函数 导致 的 错误 信息 。 


沁 信 于 和 0 关 沁 信 浙江 志 / 尖 硬 
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例如 以 下 代码 : 

<?php 
$ab = fopen("123.txt", "r"); // 打 开 指定 的 文件 
fclose(); // 关 闭 指定 的 文件 


> 


由 于 指定 的 文件 不 存在 ， 所 以 运行 后 会 弹出 如 图 7-15 所 示 的 错误 信息 。 


厨 rtpy/oc-. 攻 DD- CX) localhost x Re 
HP MAE) EM kiN ITRI mm | 


| Function Location 
1 0. 0005 138480| {mainj ( ) | \l.php:0 
2 0.0138 139072|fopen ( ) | \l.php:2 


# Time Nemory Function Location 
1 0. 0005 138480 | {nainj ( ) .php:0 
2 0. 0155 139924|fclose () .php:3 


7-15 ”出 现 错误 信息 


如 果 在 fopen0) 函 数 和 fclose0 函 数 前 加 上 @ 符 号 ， 再 次 运行 程序 时 ， 就 不 会 出 现 错误 信息 
了 。 这 种 隐藏 信息 的 方法 对 于 查找 错误 的 位 置 是 很 有 帮助 的 。 
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日 期 和 时 间 对 于 很 多 应 用 来 说 是 十 分 敏感 的 ， 程 序 中 ， 很 多 情况 下 都 是 依靠 日 
期 和 时 间 才 能 做 出 判断 、 完 成 操作 的 。 例 如 酒店 商务 网 站 中 查看 最 新 的 房价 情况 ， 
这 与 时 间 是 密 不 可 分 的 。 本 章 将 介绍 日 期 和 时 间 的 获得 及 格式 化 方面 的 内 容 。 
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8.1 系统 时 区 的 设置 


这 里 的 系统 时 区 是 指 运行 PHP 的 系统 环境 。 常 见 的 有 Windows 系统 和 Unix-like( 类 Unix) 
系统 。 对 于 它们 的 时 区 的 设置 ， 关 系 到 运行 应 用 的 时 间 准 确 性 。 


8.1.1 时 区 划分 


时 区 的 划分 是 一 个 地 理 概念 。 从 本 初子 午 线 开始 向 东 和 向 西 各 有 12 个 时 区 。 比 如 我 们 的 
北京 时 间 是 东 八 区 。 美 国 太平 洋 时 间 是 西 人 区 。 在 Windows 系统 里 ， 这 个 操作 比较 简单 。 在 
控制 面板 里 设置 就 行 了 。 在 Linux 这 样 的 Unix-like 系统 中 ， 需 要 使 用 命令 对 时 区 进行 设置 。 


8.1.2 ”时 区 设置 


PHP 中 ， 日 期 时 间 的 默认 设置 是 GMT 格林 尼 治 时 间 。 在 使 用 时 间 日 期 功能 之 前 ， 需 要 
对 时 区 进行 设置 。 在 中 国 ， 就 需要 使 用 Asia/Hong_ Kong 香港 时 间 。 

时 区 的 设置 方法 主要 为 以 下 两 种 : 

@ ”修改 php.ini 文件 的 设置 。 找 到 “;date.timezone=” 选 项 ， 将 其 值 修改 为 date.timezone 
=Asia/Hong Kong， 这 样 系统 默认 时 间 为 东 八 区 的 时 间 。 

e ”在 应 用 程序 中 直接 用 函数 来 设置 ， 如 date_default_timezone set(“Asia/Hong Kong”)， 
这 种 方法 设置 时 比较 灵活 。 

设置 完成 后 ，date() 函 数 便 可 以 正常 使 用 了 ， 不 会 出 现时 差 的 问题 。 


8.2 PHP 的 日 期 和 时 间 函 数 
本 节 开 始 学 习 PHP 的 常用 日 期 和 时 间 函 数 的 使 用 方法 和 技巧 。 
8.2.1 关于 Unix 时 间 截 


在 很 多 情况 下 ， 程 序 需要 对 日 期 进行 比较 、 运 算 等 操作 。 如 果 按 照 人 们 日 常 的 计算 方 
法 ， 很 容易 知道 6 月 5 号 和 6 月 8 号 相差 几 天 。 

然而 ， 如 果 日 期 的 书写 方式 是 2012-3-8 或 2012 年 3 月 8 日 星期 五 ， 这 让 程序 如 何 运 算 
呢 ? 对 于 整 型 数据 的 数学 运算 来 说 ， 好 像 这 样 的 描述 并 不 容易 处 理 。 如 果 想 知道 3 月 8 号 和 4 
月 23 号 相差 几 天 ， 则 需要 把 月 先 转换 为 30 天 或 31 天 ， 再 对 剩余 天 数 加 减 。 这 是 一 个 很 麻烦 
的 过 程 。 

如 果 时 间或 者 日 期 是 一 个 连贯 的 整数 ， 这 样 处 理 起 来 就 很 方便 了 。 

幸运 的 是 ， 系 统 的 时 间 正 是 以 这 种 方式 储存 的 ， 这 种 方式 就 是 时 间 戳 ， 也 称 为 Unix 时 间 
玲 。Unix 系统 和 Unix-like 系统 把 当下 的 时 间 储 存 为 32 位 的 整数 ， 这 个 整数 的 单位 是 秒 ， 而 


这 个 整数 的 开始 时 间 为 格林 尼 治 时 间 (GMT) 的 1970 年 1 月 1 日 的 零点 整 。 换 名 话说， 就 是 现 
在 的 时 间 是 GMT 1970 年 1 月 1 日 的 零点 整 到 现在 的 秒 数 。 

由 于 每 一 秒 的 时 间 都 是 确定 的 ， 这 个 整数 就 像 一 个 章 戳 一 样 不 可 改变 ， 所 以 就 称 为 Unix 
时 间 戳 。 

这 个 时 间 戳 在 Windows 系统 下 也 是 成 立 的 ， 但 是 与 Unix 系统 下 不 同 的 是 ，Windows 系 
统 下 的 时 间 戳 只 能 为 正 整数 ， 不 能 为 负 值 。 所 以 想 用 时 间 惟 表示 1970 年 1 月 1 日 以 前 的 时 间 
是 不 行 的 。 

PHP 则 是 完全 采用 了 Unix 时 间 惟 的。 所 以 不 管 PHP 在 哪个 系统 下 运行 ， 都 可 以 使 用 
Unix 时 间 惟 。 


8.2.2 ”获取 当前 的 时 间 戳 


要 获得 当前 时 间 的 Unix 时 间 戳 ， 以 用 于 得 到 当前 时 间 ， 直 接 使 用 time0 函 数 即 可 。timeO 
函数 不 需要 任何 参数 ， 直 接 返回 当前 日 期 和 时 间 。 
【 例 8.1】( 示 例文 件 ch08\8.1.php) 


<HTML> 
<HEAD> 
<TITLE> 获 取 当 前 时 间 惟 </TITLE> 
</HEAD> 
<BODY> 
<?php 
Stl = time(); 
echo "当前 时 间 故 为 : " . $t1; 
?> 
</BODY> 
</HTML> 


运行 结果 如 图 8-1 所 示 。 


多 httpy/localhost Pv Cx 


当前 时 间 噬 为 ，1398145489 


8-1 获取 当前 的 时 间 戳 


案例 分 析 : 

(1) 图 8-1 中 ， 数 值 1344247868 表示 从 1970 年 1 月 1 日 0 点 0 分 0 秒 到 本 程序 执行 时 
间隔 的 秒 数 。 

(2) 如 果 每 隔 一 段 时 间 刷 新 一 次 页 面 ， 获 取 的 时 间 戳 的 值 将 会 增加 。 这 个 数 会 一 直 不 断 
地 变 大 ， 即 每 过 1 秒 ， 此 值 就 会 加 1。 


a 
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8.2.3 获取 当前 的 日 期 和 时 间 


可 使 用 date0 函 数 返 回 当前 日 期 ， 如 果 在 date0 函 数 中 使 用 参数 “U”， 则 可 返回 当前 时 
间 的 Unix 时 间 戳 。 如 果 使 用 参数 “d”， 则 可 直接 返回 当前 月 份 的 01 到 31 号 的 两 位 数 日 
期 ， 等 等 。 

date0 函 数 有 很 多 参数 ， 具 体 含义 如 表 8-1 所 示 。 

表 8-1 date() 函 数 的 参数 


参 数 含 义 参 数 含义 
大 写 AM 或 PM 
Mon 到 Sun 的 简写 星期 


a 小 写 am 或 pm 
d 01 到 31 的 日 期 
e 显示 时 区 


A 
D 
月 份 的 全 拼 单词 
g | 12 小 时 格式 的 小 时 数 (1 到 12) 24 小 时 格式 的 小 时 数 (0 到 23) 
h | 12 小 时 格式 的 小 时 数 (01 到 12) | 下 | 24 小 时 格式 的 小 时 数 (00 到 23) 
i 分 钟 数 (01 到 60) | | Daylight 
j 一 月 中 的 天 数 (从 1 到 31) 
L 一 周 中 天 数 的 全 拼 Leap year 
m | 月 份 (从 01 到 12) 三 个 字母 的 月 份 简写 (从 Jan 到 Dec) 
n 月 份 (从 1 到 12) 

| ”o | 与 格林 尼 治 时 间 相 差 的 时 间 
s | 私 数 (从 00 到 59) | s | 天 数 的 序数 表达 (st、nd、rd、th) 
t | 一 个 月 中 天 数 的 总 数 (从 28 到 31) 时 区 简写 

当前 的 Unix 时 间 稚 
Ww 数字 表示 的 周 天 ( 从 0-Sunday 到 6-Saturday) Ww ISO8601 标准 的 一 年 中 的 周 数 

至 四 位 数 的 公元 纪年 (从 1901 到 2038) 

和 一 年 中 的 天 数 (从 0 到 364) Z 以 秒表 现 的 时 区 (从 -43200 到 50400) 


8.2.4 使 用 时 间 惟 获取 日 期 信息 
如 果 相应 的 时 间 戳 已 经 储存 在 数据 库 中 ， 程 序 需要 把 时 间 戳 转化 为 可 读 的 日 期 和 时 间 ， 


才能 满足 应 用 的 需要 。 
PHP 中 提供 了 date0 和 getdateO 等 函数 来 实现 从 时 间 戳 到 通用 时 间 的 转换 。 
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1. date0 浮 数 


date0) 函 数 主要 是 将 一 个 Unix 时 间 戳 转化 为 指定 的 时 间 / 日 期 格式 。 该 函数 的 格式 如 下 : 


string date(string format， [时 间 稚 整数 ] ) 


此 函数 将 会 返回 一 个 字符 串 。 该 字符 串 就 是 一 个 指定 格式 的 日 期 时 间 ， 其 中 format 是 一 
个 字符 串 ， 用 来 指定 输出 的 时 间 格 式 。 时 间 戳 整数 可 以 为 空 ， 如 果 为 空 ， 则 表示 为 当前 时 间 


的 Unix 时 间 戳 。 
format 参数 是 由 指定 的 字符 构成 的 ， 具 体 字 符 的 含义 如 表 8-2 所 示 。 


表 8-2 format 字符 的 含义 


format 字符 含义 说 明 
a am 或 pm 
A AM 或 PM 
d 几 日 ， 二 位 数字 ， 若 不 足 二 位 ， 则 前 面 补 零 。 例 如 01 至 31 
D 星期 几 ， 三 个 英文 字母 。 例 如 Fri 
F 月 份 ， 英 文 全 名 。 例 如 January 
h 12 小 时 制 的 小 时 。 例 如 01 至 12 
H 24 小 时 制 的 小 时 。 例 如 00 至 23 
g 12 小 时 制 的 小 时 ， 不 足 二 位 不 补 零 。 例 如 1 至 12 
G 24 小 时 制 的 小 时 ， 不 足 二 位 不 补 零 。 例 如 0 至 23 
i 分 钟 。 例 如 00 至 59 
几 日 ， 二 位 数字 ， 若 不 足 二 位 不 补 零 。 例 如 1 至 31 
1 星期 几 ， 英 文 全 名 。 例 如 Friday 
m 月 份 ， 二 位 数字 ， 若 不 足 二 位 则 在 前 面 补 零 。 例 如 01 至 12 
n 月 份 ， 二 位 数字 ， 若 不 足 二 位 则 不 补 零 。 例 如 1 至 12 
M 月 份 ， 三 个 英文 字母 。 例 如 Jan 
S 秒 。 例 如 00 至 59 
S 字 尾 加 英文 序数 ， 两 个 英文 字母 。 例 如 也 、nd 
t 指定 月 份 的 天 数 。 例 如 28 至 31 
U 总 秒 数 
Ww 数值 型 的 星期 几 。 例 如 0( 星 期 日 ) 至 6( 星 期 六 ) 
音 年 ， 四 位 数字 。 例 如 1999 
y 年 ， 二 位 数字 。 例 如 99 
z 一 年 中 的 第 几 天 。 例 如 0 至 365 


本 齐 
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下 面 通过 一 个 例子 来 理解 format 字符 的 使 用 方法 。 
【 例 8.2】( 示 例文 件 ch08\8.2.php) 


<HTML> 
<HEAD> 
<TITLE> 获 取 当 前 时 间 戳 </TITLE> 
</HEAD> 
<BODY> 
<?php date default timezone set ("PRC"); 
// 定 义 一 个 当前 时 间 的 变量 
$tt = time(); 
echo "目前 的 时 间 为 : <br>"; 
// 使 用 不 同 的 格式 化 字符 测试 输出 效果 
echo date("Y 年 m 月 d 日 [1]H 点 i 分 s 秒 ", $tt)."<br>"; 
echo date("y-m-d h:i:s a",$tt)."<br>"; 
echo date("Y-M-D H:I:S A",S$tt)."<br>"; 
echo datel(l"Erdry 了 ”SEE <br>"s 
echo date("Y-M-D H:I:S",$tt)." <br>"; 
?> 
</BODY> 
</HTML> 


运行 结果 如 图 8-2 所 示 。 


文件 (月 ”编辑 (E) ”前 看 V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


目前 的 时 间 为 : 
2014 年 04 月 22 日 [Tuesday]13 点 45 分 15 秒 


14-04-22 01:45:15 pm 
2014-Apr-Tue 13:0:nd PN 
April, 22, 14 Tuesday 
2014-Apr-Tue 13:0:nd 


8-2 理解 format 字符 的 用 法 


案例 分 析 : 

(1) date_default_timezone_set(“PRC”) 语 句 的 作用 是 设置 默认 时 区 为 北京 时 间 。 如 果 不 设 
置 ， 将 会 显示 安全 警告 信息 。 

(2) 格式 化 字符 的 使 用 方法 非常 灵活 ， 只 要 设置 字符 串 中 包含 的 字符 ，dateO 函 数 就 能 将 
字符 串 蔡 换 成 指定 的 日 期 时 间 信息 。 利 用 上 面 的 函数 可 以 随意 输出 自己 需要 的 日 期 。 


2. getdateO 函 数 


getdate0) 函 数 可 以 获取 详细 的 时 间 信息 ， 函 数 的 格式 如 下 : 
array getdate (时 间 戳 整数) 


全 1 


可 记 


getdate0 函 数 返 回 一 个 数组 ， 包 含 日 期 和 时 间 的 各 个 部 分 。 如 果 它 的 参数 时 间 戳 整数 为 


@s 
第 
空 ， 则 表示 直接 获取 当前 时 间 戳 。 下 面 举例 说 明 此 函数 的 使 用 方法 和 技巧 。 "| 
【 例 8.3】( 示 例文 件 ch08\8.3.php) 筷 
日 
<HTML> 
<HEAD> 草 
<TITLE> 获 取 当 前 时 间 戳 </TITLE> ~ 
</HEAD> 
<BODY> 
<?php 


date default timezone set ("PRC"); 

// 定 义 一 个 时 间 的 变量 

$tm ="2012-08-08 08:08:08"; 

echo "时 间 为 : ". $tm. "<br>"; 

// 将 格式 转化 为 unix 时 间 惟 

$tp = StLtotime (Stm) 7 

echo "此 时 间 的 Unix 时 间 惟 为 : " .Stp. "<br>"; 
$arl = getdate ($tp); 


py A 


echo "年 为 : ". $arl year™]. "<br>"y 
echo "月 为 : ". $arl["mon"] ."<br>"; 
echo "日 为 : ". $arl mday™ "<br>™y 
echo "点 为 : ". $arl["hours"] ."<br>"; 
echo "分 为 : ". $arl["minutes"]."<br>"; 
echo " 秒 为 : ". $arl["seconds"] ."<br>"7 
KE 

</BODY> 

</HTML> 

运行 结果 如 图 8-3 所 示 。 


霸 htpyllocalhos PD- BOx|Grmsmaas x | 
文件 (月 编 恕 (日 。 豆 看 (V) ”收藏 天 (A) 工具 (T) 帮助 (H) 


时 间 为 ，2012-08-08 08:08:08 
此 时 间 的 Unix 时 间 训 为 ，1344384488 
年 为 ，2012 

8 


8 
8 
8 
8 


图 8-3 ”使 用 getdate() 函 数 
8.2.5 检验 日 期 的 有 效 性 
使 用 用 户 输入 的 时 间 数 据 时 ， 有 时 会 由 于 用 户 输入 的 数据 不 规范 ， 导 致 程 序 运 行 出 错 。 
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为 了 检查 时 间 的 合法 有 效 性 ， 需 要 使 用 checkdate0 函 数 对 输入 日 期 进行 检测 。 它 的 格式 如 下 : 
checkdate (月 份 ， 日 期 ， 年 份 ) 
此 函数 检查 的 项 目 是 ， 年 份 整数 是 否 在 0-32767 之 间 ， 月 份 整数 是 否 在 1~12 之 间 ， 日 期 


整数 是 否 在 相应 的 月 份 的 天 数 内 。 下 面 通 过 例子 来 讲述 如 何 检查 日 期 的 有 效 性 。 
【 例 8.4】( 示 例文 件 ch08\8.4.php) 


<HTML> 


<HEAD> 
<TITLE> 检 查 日 期 的 有 效 性 </TITLE> 
</HEAD> 


<BODY> 
<?php 
if(checkdate (2,31,2012)){ 
echo "这 不 可 能 。"; 
}else{ 
echo "2 月 没有 31 号 。"; 
} 
人 > 
</BODY> 
</HTML> 


运行 结果 如 图 8-4 所 示 。 


碟 http://localhost PD- BCX 
文件 (F) ”编辑 (E) ”前 看 (V) ”收藏 夫 (A) 工具 (T) ”帮助 (H) 


2 月 没有 31 号 。 


图 8-4 ”使 用 checkdate() 函 数 对 输入 日 期 进行 检测 
8.2.6 输出 格式 化 时 间 戳 的 日 期 和 时 间 
使 用 strftime0 可 以 把 时 间 戳 格式 化 为 日 期 和 时 间 。 它 的 格式 如 下 : 
strftime (格式 ， 时 间 戳 ) 


其 中 有 两 个 参数 ， 格 式 决 定 了 如 何 把 其 后 面 时 间 戳 格式 化 并 且 输 出 出 来 。 如 果 时 间 戳 为 
空 ， 则 系统 当前 时 间 戳 将 会 被 使 用 。 
关于 格式 代码 的 含义 ， 如 表 8-3 所 示 。 


. 
全 i's 


可 


第 
表 8-3 格式 代码 的 含义 如 
代 码 委 湾 : 含义 入 
%a 周 日 期 ( 缩 简 ) 周 日 期 是 
%b 或 6h 月 份 ( 缩 简 ) 月 份 六 
%c 标准 格式 的 日 期 和 时 间 世纪 间 
%d 月 日 期 (从 01 到 31) %D 日 期 的 缩 简 格 式 (mnydd/yy) 
到 包含 两 个 字符 的 字符 串 月 日 期 
(从 01 到 '317) 
%g 根据 周 数 的 年 份 (2 个 数字 ) %G 根据 周 数 的 年 份 (4 个 数字 ) 
%H 小 时 数 (从 00 到 23) RN 
%I 小 时 数 (从 1 到 12) NN 
%j 一 年 中 的 天 数 ( 从 001 到 366) SS 
%m %M 分 钟 (从 00 到 59) RS 
%n 新 一 行 ( 同 \n) 
%p am 或 pm 
or 时 间 使 用 24 小 时 制 表示 
秒 (从 00 到 59) 


oa 时 间 使 用 hhssimm 格式 表示 


周 天 数 . 一 年 中 的 周 数 ( 从 第 一 周 的 第 
%% % 
(从 1-Monday 到 7-Sunday) 一 个 星期 天 开始 ) 


二 一 年 中 的 周 数 (以 至 少 剩余 四 
" 天 的 这 一 周 开始 为 第 一 周 ) 
周 天 数 本 一 年 中 的 周 数 (从 第 一 周 的 第 
(从 0-Sunday 到 6-Saturday) 上 一 个 星期 一 开始 ) 


ox 标准 格式 日 期 无 时 间 ) 标准 格式 时 间 ( 无 日 期 ) 
oy 年 份 2 字符 ) 年 份 (4 字符 ) 
oz 和 ?2 


下 面 举例 介绍 用 法 。 
【 例 8.5】( 示 例文 件 ch08\8.5.php) 


<HTML> 

<HEAD><TITLE> 输 出 格式 化 日 期 和 时 间 </TITLE></HEAD> 

<BODY> 

<?php 

date default timezone set ("PRC"); 

echol(strftime("%b %d %Y %X", mktime(20,0,0,12,31,98))); 
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echo(gmstrftime("%b %d %Y %X", mktime(20,0,0,12,31,98))); 

// 输 出 当前 日 期 、 时 间 和 时 区 

echo(gmstrftime("It is %a on %b %d, %Y, %X time Zone: %2",time())); 
2 

</BODY> 

</HTML> 


运行 结果 如 图 8-5 所 示 。 


LEE Ex| 
[< |@ napylocahos P - BO x | Smee x | | 


文件 (有 ] ” 编 铝 {E) ”前 看 (V) 收藏 夫 (A) ”工具 (D ”帮助 (H) 


Dec 31 1998 20:00:00Dec 31 1998 12:00:00It is Tue on Apr 22, 
标准 时 间 


2014，05:46:10 time zone: 中 国 


图 8-5 输出 格式 化 日 期 和 时 间 
8.2.7 显示 本 地 化 的 日 期 和 时 间 


由 于 世界 上 有 不 同 的 显示 习惯 和 规范 ， 所 以 日 期 和 时 间 也 会 根据 不 同 的 地 区 显示 为 不 同 
的 形式 。 这 就 是 日 期 时 间 的 本 地 化 显示 。 

实现 此 操作 需要 使 用 到 setlocale() 和 strftime() 两 个 函数 。 后 者 已 经 介绍 过 。 

使 用 setlocale0) 函 数 来 改变 PHP 的 本 地 化 默认 值 ， 实 现 本 地 化 的 设置 ， 它 的 格式 为 : 


setlocale (目录 ， 本 地 化 值 ) 


(1) 本 地 化 值 是 一 个 字符 串 ， 它 有 一 个 标准 格式 : language COUNTRY.chareacterset。 例 
如 ， 想 把 本 地 化 设 为 美国 ， 按 照 此 格式 为 en_US.utf8， 如 果 想 把 本 地 化 设 为 英国 ， 按 照 此 格 
式 为 en_GB.utfg， 如 果 想 把 本 地 化 设 为 中 国 ， 且 为 简体 中 文 ， 按 照 此 格式 为 zh_CN.gb2312， 
或 者 zh_CN.utf8。 

(2) 目录 是 指 6 个 不 同 的 本 地 化 目录 。 如 表 8-4 所 示 。 


表 8-4 本 地 化 目录 

目录 说 明 
LC AT 为 后 面 其 他 的 目录 设 定 本 地 化 规则 的 目录 
LC COLLATE 字符 串 对 比 目 录 
LC_CTYPE 字母 划 类 和 规则 
LC MONETARY 货币 表示 规则 
LC NUMERIC 数字 表示 规则 
LC TIME 日 期 和 时 间 表 示 规 则 
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由 于 这 里 要 对 日 期 时 间 进 行 本 地 化 设置 ， 需 要 使 用 到 的 目录 是 LC_TIME。 下 面 的 例子 对 
日 期 时 间 本 地 化 进行 讲解 。 
【 例 8.6】( 示 例文 件 ch08\8.6.php) 


<HTML> 
<HEAD> 

<TITLE> 显 示 本 地 化 日 期 和 时 间 </TITLE> 
</HEAD> 
<BODY> 
<?php 
date default timezone set ("PRC"); 
date default timezone set ("Asia/Hong Kong"); 
setlocale (LC TIME, "zh CN.gb2312"); 
echo strftime("%2z"); 
六 
</BODY> 
</HTML> 


运行 结果 如 图 8-6 所 示 。 


可 孚 凑 闫 中 网 只 _ 翰 8 涛 六 六 


IGG 


(TOG enor -so x] Sra ~ 


文件 (编辑 (E) ”前 看 (V) ”收藏 夫 (A) 工具 (Tm) 者 助 (H) 
中 国标 准时 间 


图 8-6 日 期 时 间 本 地 化 


案例 分 析 : 

(1) date_default_timezone_set(“Asia/Hong Kong”) 设 定时 区 为 中 国 时 区 。 
(2) setlocale0 设 置 时 间 的 本 地 化 显示 方式 为 简体 中 文 方式 。 

(3) strfime(“9%z”) 返 回 所 在 时 区 ， 其 在 页 面 显示 为 简体 中 文 方式 。 


8.2.8 将 日 期 和 时 间 解 析 为 Unix 时 间 戳 


使 用 给 定 的 日 期 和 时 间 ， 操 作 mktimeO 函 数 可 以 生成 相应 的 Unix 时 间 戳 。 它 的 格式 为 ; 
mktime (小 时 ， 分 钟 ， 秒 ， 月 份 ， 日 期 ， 年 份 ) 


把 相应 的 时 间 和 日 期 的 部 分 输入 相应 位 置 的 参数 ， 即 可 得 到 相应 的 时 间 戳 。 下 面 的 例子 
介绍 此 函数 的 应 用 方法 和 技巧 。 
【 例 8.7】( 示 例文 件 ch08\8.7.php) 


<HTML> 
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案例 课堂 »… 
<HEAD> 
<TITLE></TITLE> 
</HEAD> 
<BODY> 
<?php 


$timestamp = mktime (0,0,0,3,31,2012); 
echo $timestamp; 
> 


</BODY> 
</HTML> 
运行 结果 如 图 8-7 所 示 。 


@ htpi/localhost P ~ BO X | @localhost 


文件 (F) ” 编 强 (E) ”前 看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 


1333152000 


8-7 ”使 用 mktime() 函 数 
其 中 mktime(0,0,0,3,31,2012) 使 用 的 时 间 是 2012 年 3 月 31 号 0 点 整 。 


8.2.9 日 期 时 间 在 PHP 和 MySQL 数据 格式 之 间 转 换 


日 期 和 时 间 在 MySQL 中 是 按照 ISO8601 格式 储存 的 。 这 种 格式 要 求 以 年 份 打头 ， 如 
2012-03-08 这 种 格式 。 从 MySQL 读 取 的 默认 格式 也 是 这 种 格式 。 对 于 这 种 格式 我 们 中 国人 是 
比较 熟悉 的 。 这 样 在 中 文 应 用 中 ， 几 乎 可 以 不 用 转换 ， 就 直接 使 用 这 种 格式 。 

但 是 ， 在 西方 的 表达 方法 中 ， 经 常 把 年 份 放 在 月 份 和 日 期 的 后 面 ， 如 March 08, 2012。 所 
以 ， 在 接触 到 国际 的 ， 特 别 是 符合 英语 使 用 习惯 的 项 目 时 ， 需 要 对 ISO8601 格式 的 日 期 时 间 
做 合适 的 转换 。 

有 意思 的 是 ， 为 了 解决 这 个 英文 使 用 习惯 和 ISO8601 格式 冲突 的 问题 ，MySQL 提供 了 把 
英文 使 用 习惯 的 日 期 时 间 转 换 为 符合 ISO8601 标准 的 两 个 函数 ， 它 们 是 DATE FOMATO 和 
UNIX_TIMESTAMPO。 这 两 个 函数 在 SQL 语言 中 使 用 。 具 体 用 法 将 在 介绍 MySQL 时 详 述 。 


8.3 ”实现 倒计时 功能 


对 于 未 来 的 时 间 点 实现 倒计时 ， 其 实 就 是 使 用 现在 的 当下 时 间 玲 和 未 来 的 时 间 点 进行 比 
较 和 运算 。 
下 面 通过 案例 来 介绍 如 何 实现 倒计时 功能 。 


【 例 8.8】( 示 例文 件 ch08\8.8.php) 


<HTML> 
<HEAD> 

<TITLE> 倒 计时 </TITLE> 
</HEAD> 
<BODY> 
<?php 


$timestampfuture = mktime (0,0,0,05,01,2012); 


$timestampnow = mktime(); 


$timecount = $timestampfuture — $timestampnow; 


$days = round ($timecount/86400); 


echo "今天 是 ".date('Y F d') ."” ,距离 2012 年 5 月 1 号 的 时 间 稚 ， 还 有 ".$days." 天 。"; 


> 
</BODY> 
</HTML> 
运行 结果 如 图 8-8 所 示 。 
@ httpi/localhost PD - BO XE localhost 
文件 (月 ” 编 岛 (E) 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 
今天 是 2014 April 22 ,距离 2012 年 5 月 1 号 的 时 间 咒 ， 还 有 -721 天 。 
图 8-8 比较 两 个 时 间 的 大 小 

案例 分 析 : 


(1) mktime0 不 带 任何 参数 ， 所 生成 的 时 间 戳 是 当前 时 间 的 时 间 戳 。 
(2) $timecount 是 现在 的 时 间 戳 距离 未 来 时 间 点 的 时 间 戳 的 秒 数 。 
(3) round($timecount/86400)， 其 中 86400 为 一 天 的 秒 数 ，$timecount/86400 得 到 天 数 ， 


round() 函 数 取 约 数 ， 得 到 天 数 。 


8.4 比较 两 个 时 间 的 大 小 


对 于 比较 两 个 时 间 的 大 小 来 说 ， 如 果 通 过 一 定形 式 的 日 期 时 间 进 行 比较 ， 或 者 不 同 的 格 
式 的 时 间 日 期 进行 比较 ， 都 并 不 方便 。 最 为 方便 的 方法 是 把 所 有 格式 的 时 间 都 转换 为 时 间 


惟 ， 然 后 比较 时 间 惟 的 大 小 。 
下 面 通过 例子 来 比较 两 个 时 间 的 大 小 。 
【 例 8.9】( 示 例文 件 ch08\8.9.php) 


<HTML> 


|] 
ee 


吾 孚 兴 淮 呈 峭 只 刷 8 洲 曾 症 


py A 


15@ 


PHP+MySQL 动 态 网 站 开发 


案例 课堂 >… 
<HEAD> 
<TITLE></TITLE> 
</HEAD> 
<BODY> 
<?php 


$timestampA = mktime(0,0,0,3,31,2012); 
$timestampB = mktime (0,0,0,1,31,2012); 
if($timestampA > $timestampB){ 

echo "2012 年 三 月 的 时 间 稚 数值 大 于 2012 年 一 月 的 。"; 
}jelseif($timestampR < $timestampB){ 

echo "2012 年 三 月 的 时 间 戳 数值 小 于 2012 年 一 月 的 。"; 
}else{ 

echo "两 个 时 间 相 同 。"; 
} 


六 


</BODY> 
</HTML> 
运行 结果 如 图 8-9 所 示 。 


Ce-| 


[¢ 回 钨 htp://localhost P - 号 cd X||@localhost 


文件 (月 ”编辑 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


2012 年 三 月 的 时 间 哈 数值 大 于 2012 年 一 月 的 。 


图 8-9 比较 两 个 时 间 的 大 小 


8.5 疑难 解 惑 


疑问 1: 如 何 使 用 微 秒 单位 ? 

有 些 时 候 ， 某 些 应 用 要 求 使 用 比 秒 更 小 的 时 间 单 位 来 表示 时 间 。 比 如 在 一 段 测试 程序 运 
行 的 程序 中 ， 可 能 要 使 用 到 微 秒 级 的 时 间 单 位 来 表示 时 间 。 如 果 需 要 微 秒 ， 只 需要 使 用 函数 
microtime(true) 即 可 。 


例如 : 


<?php 

$timestamp = microtime (true); 
echo $timestamp; 

有 


返回 的 结果 为 “1315560215.7656”。 时 间 戳 精确 到 小 数 点 后 4 位。 
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疑问 2: 定义 日 期 和 时 间 时 出 现 警告 怎么 办 ? 


在 运行 PHP 程序 时 ， 可 能 会 出 现 这 样 的 警告 : PHP Warning: date(): It is not safe to rely on 
the system’s timezone settings 等 。 出 现 上 述 警 告 是 因为 PHP 所 取 的 时 间 是 格林 威 治标 准时 
间 ， 所 以 与 用 户 当地 的 时 间 会 有 出 入 ， 由 于 格林 威 治标 准时 间 与 北京 时 间 大 概 差 8 个 小 时 左 
右 ， 所 以 会 弹出 警告 。 可 以 使 用 下 面 方法 中 的 任意 一 个 来 解决 。 

(1) 在 页 头 使 用 date_default timezone _setO 设 置 默认 时 区 为 北京 时 间 ， 即 : 

<?php date default timezone set("PRC") 7 ?> 

如 本 章 例 8.2 中 所 示 。 

(2) 在 php.ini 中 设置 date.timezone 的 值 为 PRC， 设 置 语句 为 : date.timezone=PRC， 同 时 
取消 这 一 行 代码 的 注释 ， 即 去 掉 前 面 的 分 号 即 可 。 
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面向 对 象 编程 是 现在 编程 的 主流 ， 


PHP 也 不 例外 。 面 向 对 象 (object-oriented)， 
属性 等 一 系列 东西 来 提高 


不 同 于 面向 过 程 (process-oriented)， 它 用 类 、 对 象 、 关 系 、 
编程 的 效率 ， 它 主要 的 特性 是 可 封装 性 、 可 继承 性 和 多 态 性 。 本 章 主要 讲述 面向 对 
象 的 相关 知识 。 
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案例 课堂 >"… 


9.1 类 和 对 象 的 介绍 


面向 对 象 编程 的 主要 好 处 就 是 把 编程 的 重心 从 处 理 过 程 转移 到 了 对 现实 世界 实体 的 表 
达 。 这 十 分 符合 人 们 的 普通 思维 方法 。 

类 (Class) 和 对 象 (Object) 并 不 难 理解 。 试 想 一 下 ， 在 日 常生 活 中 ， 自 然 人 对 事物 的 认识 ， 
一 般 是 由 看 到 的 、 感 受到 的 实体 对 象 (日 常生 活 中 的 吃 、 穿 、 住 、 用 ) 归 纳 出 来 的 或 者 抽象 出 来 
的 类 特征 ， 这 就 是 人 们 认识 世界 的 过 程 。 

然而 程序 编写 者 需要 在 计算 机 的 世界 中 再 造 一 个 虚拟 的 “真实 世界 ”。 那 么 ， 在 这 里 ， 
程序 员 就 要 像 “ 造 物 主 ” 一 样 思考 。 就 要 先 定义 “类 ”， 然 后 再 由 “类 ”产生 一 个 个 “ 实 
体 ”， 也 就 是 一 个 个 “对 象 ”。 

有 这 样 的 情况 : 过 年 的 时 候 ， 有 的 地 方 要 制作 “点 心 ”， 点 心 一 般 会 有 鱼 、 免 、 狗 等 生 
动 的 形状 。 而 这 些 不 同 的 形状 是 由 不 同 的 “模具 ”做 出 来 的 。 那 么 ， 在 这 里 ， 鱼 、 免 、 狗 的 
一 个 个 不 同 的 点 心 就 是 实体 ， 则 最 先 刻 好 的 “模具 ”就 是 类 。 要 明白 一 点 ， 这 个 “模具 ” 指 
的 是 被 刻 好 的 “形状 ”， 而 不 是 制作 “模具 ”的 材料 。 如 果 你 能 像 造物 主 一 样 用 意念 制作 出 
一 个 个 点 心 。 那 么 ， 你 的 意念 的 “形状 ”就 是 “模具 ”。 

OOP 是 面向 对 象 编程 (Object-oriented Programming) 的 缩写 。 对 象 (Object) 在 OOP 中 是 由 
属性 和 操作 组 成 的 。 属 性 (Attribute) 是 对 象 的 特性 或 是 与 对 象 关 联 的 变量 。 操 作 (Operation) 是 
对 象 中 的 方法 (Method) 或 函数 (Function)。 

由 于 OOP 中 最 为 重要 的 特性 之 一 就 是 可 封装 性 ， 所 以 对 Object 内 部 数据 的 访问 ， 只 能 通 
过 对 象 的 “操作 ”来 完成 ， 这 也 被 称 为 对 象 的 “接口 ”(Interfaces)。 

因为 类 是 对 象 的 模板 ， 所 以 类 描述 了 它 的 对 象 的 属性 和 方法 。 

另外 ， 面 向 对 象 编程 具有 3 大 特点 。 

(1) 封装 性 

将 类 的 使 用 和 实现 分 开 管理 ， 只 保留 类 的 接口 ， 这 样 开发 人 员 就 不 用 去 知道 类 的 实现 过 
程 ， 只 需要 知道 如 何 使 用 类 即 可 ， 从 而 提高 了 开发 效率 。 

(2) 继承 性 

继承 是 面向 对 象 软件 技术 中 的 一 个 概念 。 如 果 一 个 类 A 继承 自 另 一 个 类 B， 就 把 这 个 A 
称 为 “B 的 子 类 ”， 而 把 B 称 为 “A 的 父 类 ”。 继 承 可 以 使 得 子 类 具有 父 类 的 各 种 属性 和 方 
法 ， 而 不 需要 再 次 编写 相同 的 代码 。 在 子 类 继承 父 类 的 同时 ， 可 以 重新 定义 某 些 属性 ， 并 重 
写 某 些 方法 ， 即 覆盖 父 类 的 原 有 属性 和 方法 ， 从 而 获得 与 父 类 不 同 的 功能 。 另 外 ， 还 可 以 为 
子 类 追加 新 的 属性 和 方法 。 继 承 可 以 实现 代码 的 可 重用 性 ， 简 化 了 对 象 和 类 的 创建 过 程 。 另 
外 ，PHP 支持 单 继 承 ， 也 就 是 一 个 子 类 只 能 有 一 个 父 类 。 

(3) 多 态 性 

多 态 是 面向 对 象 程序 设计 的 重要 特征 之 一 ， 是 扩展 性 在 “继承 ”之 后 的 又 一 重大 表现 。 
同一 操作 作用 于 不 同类 的 实例 ， 将 产生 不 同 的 执行 结果 ， 即 不 同类 的 对 象 收 到 相同 的 消息 
时 ， 将 得 到 不 同 的 结果 。 


9.2 ”类 的 基本 操作 


类 是 面向 对 象 中 最 为 重要 的 概念 之 一 ， 是 面向 对 象 设计 中 最 基本 的 组 成 模块 。 类 可 以 简 
单 地 视 为 一 种 数据 结构 ， 在 类 中 的 数据 和 函数 称 为 类 的 成 员 。 


9.2.1 类 的 声明 
在 PHP 中 ， 声 明 类 的 关键 字 是 class， 声 明 格式 如 下 : 


<?php 

权限 修饰 符 class 类 名 { 
类 的 内 容 ; 

} 


2> 

其 中 ， 权 限 修饰 符 是 可 选项 ， 常 见 的 修饰 符 包 括 public、private 和 protected。 创 建 类 时 ， 
可 以 省 略 权限 修饰 符 ， 此 时 默认 的 修饰 符 为 public。 三 种 权限 修饰 符 的 区 别 如 下 。 

(1) 一 般 情 况 下 ， 属 性 和 方法 默认 是 public 的 ， 这 意味 着 一 般 的 属性 和 方法 从 类 的 内 部 
和 外 部 都 可 以 访问 。 

(1) 用 关键 字 private 声明 的 属性 和 方法 ， 则 只 能 从 类 的 内 部 访问 ， 也 就 是 说 ， 只 有 类 内 
部 的 方法 可 以 访问 用 此 关键 字 声明 的 类 的 属性 和 方法 。 

(2) 用 关键 字 protected 声明 的 属性 和 方法 ， 也 是 只 能 从 类 的 内 部 访问 ， 但 是 ， 通 过 “ 继 
承 ” 而 产生 的 “ 子 类 ”， 也 可 以 访问 这 些 属性 和 方法 。 

例如 ， 定 义 一 个 学 生 为 公共 类 ， 代 码 如 下 : 


public class Student { 


// 类 的 内 容 


前 溃 沙 妆 可 琶 几 6 小 1 


py A 


9.2.2 成 员 属 性 


成 员 属性 是 指 在 类 中 声明 的 变量 。 在 类 中 可 以 声明 多 个 变量 ， 所 以 对 象 中 可 以 存在 多 个 
成 员 属性 ， 每 个 变量 将 存储 不 同 的 对 象 属性 信息 。 

例如 以 下 定义 : 

public class Student { 

public $name; // 类 的 成 员 属性 

和 

成 员 属性 必须 使 用 关键 词 进行 修饰 ， 常 见 的 关键 词 包括 public、protected 和 private 等 。 

如 果 没 有 特定 的 意义 ， 仍 然 需要 var 关键 词 修饰 。 另 外 ， 在 声明 成 员 属 性 时 ， 可 以 不 进 
行 赋值 操作 。 
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9.2.3 成 员 方法 


成 员 方 法 是 指 在 类 中 声明 的 函数 。 在 类 中 可 以 声明 多 个 函数 ， 所 以 对 象 中 可 以 存在 多 个 
成 员 方法 。 类 的 成 员 方法 可 以 通过 关键 字 进 行 修饰 ， 从 而 控制 成 员 方法 的 使 用 权限 。 
例如 以 下 定义 成 员 方 法 的 例子 : 


class Student { 
public $name; // 类 的 成 员 属性 
function GetIp(){ 
// 方 法 的 内 容 
} 
} 


9.2.4 ”类 的 实例 化 


面向 对 象 编程 的 思想 是 一 切 皆 为 对 象 。 类 是 对 一 个 事物 抽象 出 来 的 结果 ， 因 此 ， 类 是 抽 
象 的 。 对 象 是 某 类 事物 中 具体 的 那个 ， 因 此 ， 对 象 就 是 具体 的 。 例 如 ， 学 生 就 是 一 个 抽象 概 
念 ， 即 学 生 类 ， 但 是 姓名 叫 张 三 的 就 是 学 生 类 中 具体 的 一 个 学 生 ， 即 对 象 。 

类 和 对 象 可 以 描述 为 如 下 关系 。 类 用 来 描述 具有 相同 数据 结构 和 特征 的 “一 组 对 象 ”， 
“类 ”是 “对 象 ”的 抽象 ， 而 “对 象 ”是 “类 ”的 具体 实例 ， 即 一 个 类 中 的 对 象 具 有 相同 的 
“型 ”， 但 其 中 每 个 对 象 却 具 有 各 不 相同 的 “ 值 ”。 

3 类 是 具有 相同 或 相仿 结构 、 操 作 和 约束 规则 的 对 象 组 成 的 集合 ， 而 对 象 是 某 一 类 


此。 的 具体 化 实例 ， 每 一 个 类 都 是 具有 某 些 共同 牡 的 对 象 的 抽象。 


类 的 实例 化 格式 如 下 : 
$ 变 量 名 = new 类 名 称 ( [参数 ] ) ; // 类 的 实例 化 


其 中 ，new 为 创建 对 象 的 关键 字 ，“$ 变 量 名 ”返回 对 象 的 名 称 ， 用 于 引用 类 中 的 方法 。 
参数 是 可 选 的 ， 如 果 存 在 参数 ， 则 用 于 指定 类 的 构造 方法 初始 化 对 象 使 用 的 值 ， 如 果 没 有 定 
义 构造 函数 参数 ，PHP 会 自动 创建 一 个 不 带 参数 的 默认 构造 函数 。 


例如 下 面 的 例子 : 
class Student { 

public $name; // 类 的 成 员 属 性 

function GetIp(){ 

// 方 法 的 内 容 ; 

1 
} 
$1ili = new Student (); // 类 的 实例 化 
$liufei = new Student () 7 // 类 的 实例 化 
$zhangming = new Student () 7 // 类 的 实例 化 
$wangyi = new Student () 7 // 类 的 实例 化 
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上 面 的 例子 实例 化 了 4 个 对 象 ， 并 且 这 4 个 对 象 之 间 没 有 任何 联系 ， 只 能 说 明 是 源 于 同 
一 个 类 。 可 见 ， 一 个 类 可 以 实例 化 多 个 对 象 ， 每 个 对 象 都 是 独立 存在 的 。 


9.2.5 ”访问 类 中 的 成 员 属性 和 方法 


通过 对 象 的 引用 ， 可 以 访问 类 中 的 成 员 属性 和 方法 ， 这 需要 使 用 特殊 的 运算 符 “->”。 
具体 的 语法 格式 如 下 : 


$ 变 量 名 = new 类 名 称 () ; // 类 的 实例 化 

$ 变 量 名 -> 成 员 属性 = 值 ; // 为 成 员 属性 赋值 

$ 变 量 名 -> 成 员 属性 // 直 接 获 取 成 员 的 属性 值 
$ 变 量 名 -> 成 员 方法 // 访 问 对 象 中 指定 的 方法 
另外 ， 程 序 员 还 可 以 使 用 一 些 特殊 的 访问 方法 。 

1. $this 


$this 存在 于 类 的 每 一 个 成 员 方法 中 ， 它 是 一 个 特殊 的 对 象 引 用 方法 。 成 员 方 法 属于 哪个 
对 象 ，$this 引用 就 代表 哪个 对 象 ， 主 要 作用 是 专门 完成 对 象 内 部 成 员 之 间 的 访问 。 


2. 操作 符 “::” 
操作 符 “::” 可 以 在 没有 任何 声明 实例 的 情况 下 访问 类 中 的 成 员 。 使 用 的 语法 格式 如 下 : 
关键 字 : :变量 名 /常量 名 /方法 名 


其 中 关键 字 主 要 包括 parent、self 和 类 名 3 种 。parent 关键 字 表 示 可 以 调用 父 类 中 的 成 员 
变量 、 常 量 和 成 员 方 法 。self 关键 字 表 示 可 以 调用 当前 类 中 的 常量 和 静态 成 员 。 类 名 关键 字 表 
示 可 以 调用 本 类 中 的 常量 、 变 量 和 方法 。 

以 下 例子 介绍 类 的 声明 和 实例 生成 ， 其 中 将 描述 在 酒店 订房 的 客人 。 

【 例 9.1】( 示 例文 件 ch09\9.1.php) 


<html> 
<head> 
<title> 类 的 声明 和 实例 的 生成 </title> 
</head> 
<body> 
<?php 
class guests{ 
private $name; 
private $gender; 
function setname ($name){ 
$this->name = $name; 
} 
function getname(){ 
return $this->name; 
} 
function setgender ($gender){ 
$this->gender = $gender; 
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function getgender (){ 
return $this->gender; 

' 
}; 
$xiaoming = new guests; 
$xiaoming->setname ("王小明 "); 
$xiaoming->setgender (" 男 "); 
$1ili = new guests; 
$1ili->setname (" 李 莉莉 ") ; 
$1ili->setgender (" 女 "); 
echo $xiaoming->getname()."\t".$xiaoming->getgender()."<br />"; 
echo $1ili->getname()."\t".$1ili->getgender(); 
> 
</body> 
</html> 


运行 结果 如 图 9-1 所 示 。 


ED 
文件 (篇 回 (E) ， 坦 看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 


| 王小明 男 
者 南 妇 


图 9-1 介绍 类 的 声明 和 实例 生成 


案例 分 析 : 

(1) 用 class 关键 字 声明 了 一 个 类 ， 这 个 类 的 名 称 是 guests。 在 大 括号 内 写 入 类 的 属性 和 
方法 。 其 中 private $name、private $gender 为 类 guests 的 自 有 属性 ， 用 private 关键 字 声明 ， 也 
就 是 说 ， 只 有 在 类 内 部 的 方法 可 以 访问 它们 ， 类 外 部 是 不 能 访问 的 。 

(2) function setname($name)、 function getname()、function setgender($gender) 、function 
getgender() 是 类 的 方法 ， 它 们 可 以 对 private $Sname、private $gender 这 两 个 属性 进行 操作 。 
S$this 是 对 类 本 身 的 引用 。 用 “->” 连 接 类 属性 ， 格 式 如 S$this->name、S$this->gender。 

(3) 用 new 关键 字 生 成 一 个 对 象 ， 格 式 为 $xiaoming = new Classname; 它 的 对 象 名 是 
$xiaoming。 当 程序 通过 new 生成 一 个 类 guests 的 实例 ， 也 就 是 对 象 Sxiaoming 的 时 候 ， 对 象 
Sxiaoming 就 拥有 了 类 guests 的 所 有 属性 和 方法 。 然 后 就 可 以 通过 “接口 ”， 也 就 是 这 个 对 象 
的 方法 ( 即 类 的 方法 的 副本 ) 来 对 对 象 的 属性 进行 操作 。 

(4) 通过 接口 setname($name) 给 实例 $xiaoming 的 Sname 属性 赋值 为 王小明"”， 通 过 
setgender($gender) 给 实例 $xiaoming 的 Sgender 属性 赋值 为 “ 男 "。 同 样 道理 ， 通 过 接口 操作 了 实 
例 $lili 的 属性 。 最 后 通过 接口 getname()、getgender0 返 回 不 同 的 两 个 实例 的 Sname 属性 和 
Sgender 属性 ， 并 且 打 印 出 结果 。 


9.3 ”构造 方法 和 析 构 方法 


构造 方法 存在 于 每 个 声明 的 类 中 ， 主 要 作用 是 执行 一 些 初 始 化 任务 。 如 果 类 中 没有 直接 
声明 构造 方法 ， 那 么 类 会 默认 地 生成 一 个 没有 参数 且 内 存 为 空 的 构造 方法 。 

在 PHP 中 ， 声 明 构 造 方法 的 方式 有 两 种 ， 在 PHP 5 版 本 之 前 ， 构 造 方 法 的 名 称 必须 与 类 
名 相同 ; 从 PHP 5 版 本 开始 ， 构 造 方法 的 方法 名 称 必 须 是 两 个 下 划 线 开头 的 ， 即 
“_xonstruct”。 具 体 的 语法 格式 如 下 : 


function _construct([mixed args]){ 


// 方 法 的 内 容 


一 个 类 只 能 声明 一 个 构造 方法 。 构 造 方法 中 的 参数 是 可 选 的 ， 如 果 没 有 传 入 参数 ， 那 么 
将 使 用 默认 参数 为 成 员 变 量 进行 初始 化 。 

在 例 9.1 中 ， 对 实例 $xiaoming 的 $name 属性 赋值 时 还 需要 通过 使 用 接口 setname($name) 
进行 操作 ， 如 $xiaoming->setname(“XiaoMing”)。 如 果 想 在 生成 实例 $xiaoming 的 同时 就 对 此 实 
例 的 属性 $name 进行 赋值 ， 该 怎么 办 呢 ? 

这 时 就 需要 构造 方法 _construct0 了 。 这 个 函数 的 特性 是 ， 当 通过 关键 字 new 生成 实例 的 
时 候 ， 它 就 会 被 调用 执行 ， 它 的 用 途经 常 就 是 对 一 些 属 性 进行 初始 化 ， 也 就 是 对 一 些 属性 进 
行 初始 化 的 赋值 。 

以 下 例子 介绍 构造 方法 的 使 用 方法 和 技巧 。 

【 例 9.2】( 示 例文 件 ch09\9.2.php) 


<html> 
<head> 
<title> 构 造 方法 </title> 
</head> 
<body> 
<?php 
class guests{ 
private $name; 
private $gender; 
function _ construct ($name,$gender){ 
$this->name = $name; 
$this->gender = $gender; 
function getname(){ 
return $this->name; 
四 
function getgender(){ 
return $this->gender; 
下 
] 
$xiaoming = new guests (" 赵 大 勇 "," 男 ") ; 


A 


前 溃 沙 妆 可 国 几 6 浇 1 


py A 


16@ 


信 n 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 B- 


$1ili = new guests ("方芳 芳 "," 女 "); 

echo $xiaoming->getname()."\t".$xiaoming->getgender()."<br />"; 
echo $1ili->getname()."\t".$1ili->getgender(); 

2 

</body> 

</html> 


运行 结果 如 图 9-2 所 示 。 


原 htpylloc- 起 只 - 昌 C X | 铭 构 村 方 法 
文件 (F) ”编辑 (E) ”查看 V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


赵 大 勇 男 
方芳 芳 女 


图 9-2 使 用 构造 方法 


要 记 住 的 是 ， 构 造 方法 是 不 能 返回 (return) 值 的 。 

有 构造 方法 ， 就 有 它 的 反面 “ 析 构 方法 ”(destructor)。 它 是 在 对 象 被 销毁 的 时 候 被 调用 执 
行 的 。 但 是 因为 PHP 在 每 个 请 求 的 最 终 都 会 把 所 有 资源 释放 ， 所 以 析 构 方法 的 意义 是 有 限 
的 。 具 体 使 用 的 语法 格式 如 下 : 

function destruct(){ 

// 方 法 的 内 容 ， 通 常 是 完成 一 些 在 对 象 销毁 前 的 清理 任务 

) 

PHP 具有 垃圾 回收 机 制 ， 可 以 自动 清除 不 再 使 用 的 对 象 ， 从 而 释放 更 多 的 内 存 。 析 构 方 
法 是 在 垃圾 回收 程序 执行 前 被 调用 的 方法 ， 是 PHP 编程 中 的 可 选 内 容 。 

不 过 ， 析 构 方 法 在 某 些 特定 行为 中 还 是 有 用 的 ， 比 如 在 对 象 被 销毁 时 清空 资源 或 者 记录 
日 志 信息 。 

以 下 两 种 情况 中 ， 析 构 方法 可 能 被 调用 执行 : 

@ ”代码 运行 时 ， 当 所 有 的 对 于 某 个 对 象 的 reference( 引 用 ) 被 毁 掉 的 情况 下 。 

@ ”当代 码 执行 到 最 终 ， 并 且 PHP 停止 请 求 的 时 候 。 


94 访问 器 


另外 一 个 很 好 用 的 函数 是 访问 方法 (accessor)， 又 称 访问 器 。 由 于 OOP 思想 并 不 鼓励 直接 
从 类 的 外 部 访问 类 的 属性 ， 以 强调 封装 性 ， 所 以 可 以 使 用 _get 和 __set 方法 来 达到 此 目的 。 
无 论 何 时 ， 类 属性 被 访问 和 操作 时 ， 访 问 方法 都 会 被 激发 。 通 过 使 用 它们 ， 可 以 避免 直接 对 
类 属性 的 访问 。 

以 下 例子 介绍 访问 器 的 使 用 方法 和 技巧 。 

【 例 9.3】( 示 例文 件 ch09\9.3.php) 


<html> 


加 


<head> 
<title> 访 问 器 </title> 
</head> 
<body> 
<?php 
class guestsi 
public $property; 
function set ($propName, $propValue){ 
$this->$propName = $propValue; 


aa 二 6 关 量 


} 
function _ get($propName){ 
return $this->$propName; 


i 
}; 
$xiaoshuai = new guests; 
$xiaoshuai->name = " 刘 小 帅 "7 
$xiaoshuai->gender = "男性 "; 
$dingdang = new guests; 
$dingdang->name = "本 叮当" 
$dingdang->gender = "女性 "; 
$dingdang->age = 28; 
echo $xiaoshuai->name." 是 ".$xiaoshuai->gender."<br />"; 
echo $dingdang->name." 是 一 位 ".$dingdang->age 

." 岁 ".$dingdang->gender."<br />"; 


IGG 


Sa 
</body> 
</html> 
运行 结果 如 图 9-3 所 示 。 
htpyloc-. B PD- 8Cx| Gwe 
文件 (有 ”编辑 (E) 。 查看 收 项 夫 (A) 工具 MT) #1” 
刘 小 帅 是 男性 . 
丁 叮 当 是 一 位 28 岁 女性 
图 9-3 ”使 用 访问 器 
案例 分 析 : 


(1) $xiaoshuai 为 类 guest 的 实例 。 直 接 添加 属性 name 和 gender， 并 且 赋 值 。 如 
S$xiaoshuai->name =“ 刘 小 帅 ”: $xiaoshuai->gender =“ 男 性” 此 时 ， 类 guest 中 的 _set 函数 被 调 
用 。$dingdang 实例 为 同样 的 过 程 。 另 外 ，$dingdang 实例 添加 了 一 个 对 象 属性 age。 

(2) echo 命令 中 使 用 到 的 对 象 属性 ， 如 $xiaoshuai->name 等 ， 则 是 调用 了 类 guest 中 的 
get 函数 。 

(3) 此 例 中 ， __Set 方法 的 格式 为 : 


function _ set($propName, $propValue){ 
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$this->$propName = $propValue; 


_ get 方法 的 格式 为 : 


function get ($propName) { 
return $this->$propName; 


其 中 ，$propName 为 “属性 名 ”，S$propValue 为 “属性 值 ”。 


9.5 类 的 继承 


继承 (Inheritance) 是 OOP 中 最 为 重要 的 特性 与 概念 。 父 类 拥有 其 子 类 的 公共 属性 和 方法 。 
子 类 除了 拥有 父 类 具有 的 公共 属性 和 方法 外 ， 还 拥有 自己 独 有 的 属性 和 方法 。 

PHP 使 用 关键 字 extends 来 确认 子 类 和 父 类 ， 实 现 子 类 对 父 类 的 继承 。 

具体 的 语法 格式 如 下 : 


class 子 类 名 称 extends 父 类 名 称 { 
// 子 类 成 员 变量 列表 
function 成 员 方 法 () { // 子 类 成 员 方 法 
// 方 法 内 容 
于 
3 


下 面 的 例子 介绍 类 的 继承 方法 。 
【 例 9.4】( 示 例文 件 ch09\9.4.php) 


<html> 
<head> 
<title> 类 的 继承 </title> 
</head> 
<body> 
<?php 
class Vegetables{ 
var $tomato = "西红柿 "; // 定 义 变量 
var $cucumber = "黄瓜 "; 
和 
class VegetablesType extends Vegetablesi{ // 类 之 间 继 承 
var $potato = "马铃薯 "; // 定 义 子 类 的 变量 
var $radish = "萝卜 "; 
] 
$vegetables = new VegetablesType(): // 实 例 化 对 象 
echo "蔬菜 包括 : " .$vegetables->tomato.", ".S$vegetables->t cucumber 
= Vegetables=> potato.”" , -Vegetables=>- radisashy 
人 
</body> 
</html> 
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9-4 ”使 用 类 继承 


案例 分 析 : 
从 结果 可 以 看 出 ， 本 例 创 建 了 一 个 蔬菜 父 类 ， 子 类 通过 关键 字 extends 继承 了 蔬菜 父 类 中 
的 成 员 属性 ， 最 后 对 子 类 进行 了 实例 化 操作 。 


9.6 ”抽象 类 和 接口 


抽象 类 和 接口 都 是 特殊 的 类 ， 因 为 它们 都 不 能 被 实例 化 。 本 节 主 要 讲述 两 者 的 使 用 方法 
和 技巧 。 


9.6.1 抽象 类 


抽象 类 只 能 作为 父 类 使 用 ， 因 为 抽象 类 不 能 被 实例 化 。 抽 象 类 使 用 关键 字 abstract 来 声 
明 ， 具 体 的 使 用 语法 格式 如 下 : 
abstract class 抽象 类 名 称 { 


多 HG 


// 抽 象 类 的 成 员 变量 列表 
abstract function 成 员 方 法 1 (参数 ) ; // 抽 象 类 的 成 员 方 法 
abstract function 成 员 方 法 2 (参数 ) ; // 抽 象 类 的 成 员 方法 


. 


抽象 类 与 普通 类 的 主要 区 别 在 于 ， 抽 象 类 的 方法 没有 方法 内 容 ， 而 且 至 少 包 含 一 个 抽象 
方法 。 另 外 抽象 方法 也 必须 使 用 关键 字 abstract 来 修饰 ， 抽 象 方法 后 必须 有 分 号 。 
【 例 9.5】( 示 例文 件 ch09\9.5.php) 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 抽 象 类 </title> 
</head> 
<body> 
<?php 
abstract class MyObject{ 
abstract function service($getName, $price, $num); 
人 
class MYBook extends MyObject{ 
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function service($getName, $price, $num){ 
echo ' 购 买 的 商品 是 ' .$getName .'， 商 品 的 价格 是 : ' .$price.' 元 。'; 
echo ' 您 购买 的 数量 为 :' .$num.， 本 。'; 
4 
class MyComputer extends MyObject{ 
function service ($getNamev $price, $num){ 
echo ' 您 购买 的 商品 是 ' . $getName . '， 该 商品 的 价格 是 : '.Sprice.' 元 。'; 
echo ' 您 购买 的 数量 为 :' .$num.， 本 。'; 
} 
3 
$book = new MyBook(); 
$computer = new MyComputer () 7 
$book -> service(' 《PHP5.5 从 零度 开始 学 》' ,59,15); 
echo '<p>'; 
$computer -> service('MySQL5.6 从 零 开 始 学 ' :165,10); 
芝兰 
</body> 
</html> 


运行 结果 如 图 9-5 所 示 。 


(€ 1» Er EEC Er 


文件 (站 久久 (查看 (V) 。 收 功 闪 (A。 工具 (T) 帮助 (H) 
| 购买 的 商品 是 《PHP5.5 从 零度 开始 学 》， 商 品 的 价格 是 ，59 元 。 您 购买 的 数量 为 ，15 本 。 


您 购买 的 商品 是 lySQL5. 6 从 零 开始 学 ， 该 商品 的 价格 是 ，65 元 。 您 购买 的 数量 为 ，10 本 。 
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9.6.2 接口 


继承 特性 简化 了 对 象 、 类 的 创建 ， 增 加 了 代码 的 可 重用 性 。 但 是 PHP 只 支持 单 继承 ， 如 
果 想 实现 多 继承 ， 就 需要 使 用 接口 。PHP 可 以 实现 多 个 接口 。 

接口 类 通过 关键 字 interface 来 声明 ， 接 口中 不 能 声明 变量 ， 只 能 使 用 关键 字 const 声明 为 
常量 的 成 员 属 性 ， 接 口中 声明 的 方法 必须 是 抽象 方法 ， 并 且 接口 中 所 有 的 成 员 都 必须 是 public 


的 访问 权限 。 
具体 的 使 用 语法 格式 如 下 : 
interface 接口 名 称 { // 使 用 interface 关键 字 声明 接口 
// 常 量 成 员 // 接 口中 的 成 员 只 能 是 常量 
// 抽 象 方法 // 成 员 方 法 必须 是 抽象 方法 


Gn 


以 下 示例 通过 酒店 不 同类 型 房间 之 间 的 关系 来 介绍 类 之 间 的 继承 关系 ， 其 中 涉及 到 接口 
的 使 用 和 访问 修饰 符 的 使 用 。 
【 例 9.6】( 示 例文 件 ch09\9.6.php) 


<html> 

<head> 
<title> 类 的 继承 与 接口 </title> 
</head> 

<body> 

<?php 

class roomtypes{ 
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public $customertype; 
private $hotelname = "GoodHome"; 
protected $roomface = "适合 所 有 人 "; 
function _construct(){ 
$this->customertype = "everyonefit"; 
1 
function telltype(){ 
echo "此 房间 类 型 为 " .$this->customertype."。<br />"; 
} 
function hotelface(){ 
echo "此 房间 " . Sthis->roomface."。<br />"; 
1 
final function welcomeshow(){ 
echo "欢迎 光临 " . $this->hotelname."。<br />"; 


} 
class nonviproom extends roomtypest{ 
function _ construct(){ 
$this->customertype = "nonvip"; 
} 
function telltype(){ 
echo "此 ". CLASS _." 房 间 类 型 为 ".$this->customertype."。<br />"; 
} 
function hotelface(){ 
echo "此 房间 不 是 " .$this->roomface."。<br />"; 


class Viproom extends roomtypes implements showpricel{ 
function construct(){ 
$this->customertype = "vip"; 
} 
Eunction showprice(){ 


if (CLASS_ == "superviprooms"){ 
echo "价格 高 于 500 元 。<br />"; 
J}elsef{ 


echo "价格 低 于 500 元 。<br />"; 
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final class superviprooms implements showprice, showdetailf{ 
function showprice(){ 
if (_CLASS = "superviprooms"){ 
echo "价格 高 于 500 元 。<br />"; 
}elsef{f 
echo "价格 低 于 500 元 。<br />"; 


} 
} 
function showdetail(){ 
EE LASS. == "superviprooms"){ 
echo "超级 vip 客户 可 以 使 用 会 员 卡 取得 优惠 。<br />"; 
}elsef{ 


echo "普通 客户 与 vip 客户 不 能 使 用 会 员 卡 。<br />"; 


L 
} 
interface showprice{ 
function showprice(); 
} 
interface showdetailf{ 
function showdetail (); 
} 
3 
$room2046 = new roomtypes(); 
$room2046->telltype (); 
$room2046->hotelface(); 
$room2046->welcomeshow(); 
$room307 = new nonviproom(); 
$room307->telltype (); 
$room307->hotelface(); 
$roomv2 = new viproom(); 
$roomv2->telltype (); 
$roomv2->showprice(); 
$roomsuperv3 = new superviprooms () 7 
$roomsuperv3->showprice(); 
$roomsuperv3->showdetail(); 


学 交 

</body> 

</html> 

运行 结果 如 图 9-6 所 示 。 
案例 分 析 : 


(1) 类 roomtypes 拥有 类 属性 Scustomertype、$hotelname、S$roomface。 类 roomtypes 的 构 
造 函 数 给 类 属性 $customertype 赋值 为 “everyonefit*。 类 方法 有 telltypeO0 、hotelface()、 
welcomeshow()。 

(2) 类 nonviproom 使 用 extends 关键 字 继 承 了 类 roomtypes 。 此 时 roomtypes 为 
nonviproom 的 父 类 ， 而 nonviproom 为 roomtypes 的 子 类 ， 并 拥有 类 roomtypes 的 所 有 几乎 属 
性 和 方法 。 


全 htpyiloc- 四 P BOX|@localhost 
文件 (月 ” 编 蚀 (E) 。 坦 看 (V) ， 收 意 夫 (A) ”工具 (D) 帮助 (H) 


此 房间 类 型 为 everyonefit。 
dla 

迎 光 临 GoodHone。 
ood Snonvip. 
此 房间 候车 这 全 人 。 


此 房间 类 型 为 vip 
天 


价格 高 于 
超级 ie 客户 可 以 使 会 员 卡 取得 优惠 。 
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(3) 类 nonviproom 为 了 区 别 于 roomtypes， 对 其 所 继承 的 属性 和 方法 进行 了 “ 覆 写 ” 
(overriding)。 继 承 的 属性 $customertype 被 重新 赋值 为 “nonvip”"。 类 方法 telltype0 和 hotelface() 
被 重新 定义 。 CLASS_ 变量 指 代 当 前 类 的 名 称 。 

(4) 类 viproom 同样 继承 了 类 roomtypes。 它 们 之 间 也 形成 了 子 类 与 父 类 的 关系 。 同 时 ， 
类 viproom 还 通过 implements 关键 字 使 用 了 接口 (interface)showprice。 类 viproom 重新 为 继承 
的 类 属性 $customertype 赋值 为 "vip"， 并 且 定 义 了 接口 函数 showprice()。 

(5) 类 superviprooms 直接 声明 且 继 承 了 showprice 和 showdetail 这 两 个 接口 ， 并 且 定 义 
了 接口 函数 showprice0 和 showdetail()。 

(6) 通过 关键 字 interface 声明 接口 showprice 和 showdetail， 并 且 定 义 了 接口 函数 
showprice() 和 showdetail()。 

(7) 类 roomtypes 的 类 属性 $hotelname 的 值 为 “GoodHome”， 访 问 可 见 性 为 private。 所 
以 它 的 子 类 nonviproom 和 viproom 都 无 法 访问 此 属性 。 类 roomtypes 属性 $roomface 的 值 为 
“适合 所 有 人 ”， 访 问 可 见 性 为 protected。 所 以 它 的 子 类 都 可 以 访问 。 其 子 类 nonviproom 通 
过 hotelface() 方 法 对 此 属性 进行 了 访问 。 

(8) 最 后 通过 new 关键 字 生 成 类 实例 Sroom2046、S$room307、S$roomv2、S$roomsuperv3 。 
再 通过 “->” 直 接 调 用 实例 中 的 类 方法 ， 并 得 到 如 图 9-4 所 示 的 输出 结果 。 

通过 上 面 的 例子 ， 可 以 总 结 出 如 下 的 要 点 : 

e 在 PHP 中 ， 类 的 继承 只 能 是 单独 继承 ， 也 即 是 由 一 个 父 类 ( 基 类 ) 继 承 下 去 ， 而 且 可 

以 一 直 继 承 下 去 。PHP 不 支持 多 重 继承 ， 即 不 能 由 一 个 以 上 的 父 类 进行 继承 ， 也 即 
是 类 C 不 能 同时 继承 类 A 和 类 了 B。 

@ ”由 于 PHP 不 支持 多 重 继承 ， 为 了 对 特定 类 的 功能 的 拓展 ， 就 可 以 使 用 接口 (interface) 
来 实现 类 似 于 多 重 继承 的 好 处 。 接 口 用 interface 关键 字 来 声明 ， 并 且 单 独 设立 接口 
遍 法 5 

e@ 一 个 类 可 以 继承 于 一 个 父 类 ， 同 时 使 用 一 个 或 多 个 接口 。 类 还 可 以 直接 继承 于 某 个 
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特定 的 接口 。 

e@ 类、 类 的 属性 和 方法 的 访问 ， 都 可 以 通过 放 在 属性 和 类 的 前 面 的 访问 修饰 符 进 行 控 
制 。public 为 公共 属性 或 方法 ，private 为 私有 属性 或 方法 ，protected 为 受 保护 的 可 
继承 属性 或 方法 。 

e@ ”关键 字 final 放 在 特定 的 类 前 面 ， 表 示 此 类 不 能 再 被 继承 。final 放 在 某 个 类 方法 的 前 
面 ， 表 示 此 方法 不 能 在 继承 后 被 “ 覆 写 ”或 重新 定义 。 


9.7 面向 对 象 的 多 态 性 


多 态 性 是 指 同一 操作 作用 于 不 同类 的 实例 ， 将 产生 不 同 的 执行 结果 ， 即 不 同类 的 对 象 收 
到 相同 的 消息 时 ， 得 到 不 同 的 结果 。 在 PHP 中 ， 实 现 多 态 的 方法 有 两 种 ， 包 括 通 过 继承 实现 
多 态 和 通过 接口 实现 多 态 。 
9.7.1 通过 继承 实现 多 态 


通过 继承 可 以 实现 多 态 的 效果 ， 下 面 通过 一 个 例子 来 理解 实现 多 态 的 方法 。 
【 例 9.7】( 示 例文 件 ch09\9.7.php) 


<html> 

<head> 

<title> 多 态 性 </title> 

</head> 

<body> 

<?php 

abstract class Vegetables{ // 定 义 抽象 类 Vegetables 
abstract function go_Vegetables () // 定 义 抽象 方法 go_Vegetables 

class Vegetables potato extends Vegetables{ / /马铃薯 类 继承 蔬菜 类 
public function go Vegetables (){ // 重 写 抽象 方法 

echo "我 们 开始 种 植 马 铃 暮 ”; // 输 出 信息 


} 
class Vegetables radish extends Vegetables{ // 葛 卜 类 继承 蔬菜 类 
public function go Vegetables(){ // 重 写 抽 象 方法 
echo "我 们 开始 种 植 葛 下” ; 
} 
function change ($0bj){ // 自 定义 方法 根据 对 象 调用 不 同 的 方法 
if($o0bj instanceof Vegetables){ 
$0obj->go Vegetables (); 
}elsef{f 
echo " 传 入 的 参数 不 是 一 个 对 象 "; // 输 出 信息 
1 
echo "实例 化 Vegetables potato: "7 
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change (new Vegetables _ potato()) 7 /7 实例 化 Vegetables_potato 
echo "<br>"; 

echo "实例 化 Vegetables radish: "; 

change (new Vegetables radish()); // 实 例 化 Vegetables_radish 
?> 

</body> 

</html> 


运行 结果 如 图 9-7 所 示 。 
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文件 (月 ” 妨 辑 (E) 。 坦 看 (V) 收藏 夫 (A) 工具 (T 帮助 (H) 


实例 化 Vegetables_potato: “我 们 开始 种 植 马 铃 暮 ” 
实例 化 Vegetables_radish，“ 我 们 开始 种 植 葛 卜 ” 
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图 9-7 通过 继承 实现 多 态 


案例 分 析 : 
从 结果 可 以 看 出 ， 本 例 创建 了 一 个 抽象 类 Vegetables， 用 于 表示 各 种 蔬菜 的 种 植 方法 ， 然 
后 让 子 类 继承 这 个 Vegetables。 


9.7.2 ”通过 接口 实现 多 态 


下 面 通过 接口 的 方式 ， 实 现 与 上 面 的 示例 一 样 的 效果 。 
【 例 9.8】( 示 例文 件 ch09\9.8.php) 


<html> 

<head> 

<title> 多 态 性 </title> 

</head> 

<body> 

<?php 

interface Vegetables{ // 定 义 接口 Vegetables 
public function go_Vegetables () // 定 义 接口 方法 

} 

//Vegetables potato 实现 Vegetables 接口 

class Vegetables potato implements Vegetables{ 
public function go Vegetables (){ // 定 义 go_Vegetables 方法 

echo "我 们 开始 种 植 马铃薯” // 输 出 信息 


//Vegetables radish 实现 Vegetables 接口 
class Vegetables radish implements Vegetables{ 


PHP+MySQL 动 态 网 站 开发 


案例 课堂 > 
public function go Vegetables(){ // 定 义 go_Vegetables 方法 
echo "我 们 开始 种 植 萝 卜 ” ; // 输 出 信息 
} 
function change ($0bj){ // 自 定义 方法 根据 对 象 调用 不 同 的 方法 


if($0obj instanceof Vegetables ){ 

S$obj->go Vegetables (); 
}elsef{ 

echo " 传 入 的 参数 不 是 一 个 对 象 "; // 输 出 信息 
下 


于 

echo "实例 化 Vegetables_potato: "; 

change (new Vegetables_potato()) 7 /7 实例 化 Vegetables_potato 
echo "<br>"; 

echo "实例 化 Vegetables_ radish: "; 

change (new Vegetables radish()); // 实 例 化 Vegetables radish 
</body> 

</html> 


运行 结果 如 图 9-8 所 示 。 
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实例 化 Yegetables_potato: “我 们 开始 种 植 马 铃 著 ” 
实例 化 Vegetables_radish， “我 们 开始 种 植 欧 卜 ” 
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案例 分 析 : 

从 结果 可 以 看 出 ， 本 例 创 建 Vegetables 接口 ， 然 后 定义 一 个 空 方法 go_Vegetables()， 接 
着 定义 Vegetables_potato 和 Vegetables_radish 子 类 继承 Vegetables 接口 。 最 后 通过 instanceof 
关键 字 检查 对 象 是 否 属于 Vegetables 接口 。 


9.8 疑难 解 惑 


疑问 1: 如 何 理解 “(a <b)? ab” 的 含义 ? 

这 是 条 件 控制 语句 ， 是 站 语句 的 单行 表示 法 。 它 的 具体 格式 是 : 

(条 件 判断 语句 ) ? 判断 为 rue 的 行为 : 判断 为 fal se 的 行为 

让 语句 的 单行 表示 方式 的 好 处 是 ， 可 以 直接 对 条 件 判断 的 结果 的 返回 值 进行 处 理 。 例 
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如 ， 可 以 直接 把 返回 值 赋值 给 变量 : $variable = (a<b)? a : b: 如 果 a<b 的 结果 为 tue， 则 此 语 
名 返回 a， 并 且 直 接 赋 值 给 Svariable， 如 果 a<b 的 结果 为 false， 则 此 语句 返回 b， 并 且 直 接 赋 
值 给 $variable。 

这 种 表示 方法 可 以 节约 代码 的 输入 量 ， 更 重要 的 是 可 以 提高 代码 执行 的 效率 。 由 于 PHP 
代码 执行 是 对 代码 由 上 至 下 的 一 个 过 程 ， 所 以 代码 的 行 数 越 少 ， 越 能 节约 代码 读 取 的 时 间 。 
像 这 样 在 一 行 语句 中 就 能 对 情况 做 出 判断 ， 并 且 对 代码 返回 值 进行 处 理 ， 无 疑 是 一 种 效率 相 
当 高 的 代码 组 织 方式 。 


疑问 2: 如 何 区 分 抽象 类 和 类 的 不 同 之 处 ? 


抽象 类 是 类 的 一 种 ， 通 过 在 类 的 前 面 增加 关键 字 abstract 来 表示 。 抽 象 类 是 仅仅 用 来 继承 
的 类 。 通 过 abstract 关键 字 声明 ， 就 是 告诉 PHP， 这 个 类 不 再 用 于 生成 类 的 实例 ， 仅 仅 是 用 来 
被 其 子 类 继承 的 。 可 以 说 ， 抽 象 类 只 关注 于 类 的 继承 。 抽 象 方法 就 是 在 方法 前 面 添 加 关键 字 
abstract 声明 的 方法 。 抽 象 类 中 可 以 包含 抽象 方法 。 一 个 类 中 只 要 有 一 个 方法 通过 关键 字 
abstract 声明 为 抽象 方法 ， 则 整个 类 都 要 声明 为 抽象 类 。 然 而 ， 特 定 的 某 个 类 即便 不 含 抽象 方 
法 ， 也 可 以 通过 abstract 声明 为 抽象 类 。 
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在 前 面 的 表单 章节 中 ， 已 经 实现 了 用 form 发 送 数 据 给 PHP，PHP 再 处 理 数据 
并 输出 HTML 给 浏览 器 。 在 这 样 的 一 个 流程 里 ， 数 据 会 直接 被 PHP 代码 处 理 成 
HTIML。 如 果 想 把 数据 储存 起 来 ， 并 在 需要 的 时 候 读 取 和 处 理 ， 该 怎么 办 呢 ? 这 就 
是 本 章 需要 解决 的 问题 。 在 使 用 PHP 开发 网 站 的 过 程 中 ， 文 件 的 操作 大 致 分 为 对 
普通 文本 的 操作 和 对 数据 库 文 件 的 操作 。 本 章 主 要 讲述 如 何 对 普通 文件 进行 写 入 和 
读 取 ， 以 及 目录 的 操作 、 文 件 的 上 传 等 操作 。 
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10.1 文件 操作 


在 不 使 用 数据 库 系统 的 情况 下 ， 数 据 可 以 通过 文件 (File) 来 实现 数据 的 储存 和 读 取 。 这 个 
数据 存 取 的 过 程 也 是 PHP 处 理 文件 的 过 程 。 这 里 涉及 的 文件 是 文本 文件 (Text File)。 


10.1.1 文件 数据 写 入 


对 于 一 个 文件 的 “ 读 ” 或 “ 写 ” 操 作 ， 基 本 步骤 如 下 。 

(1) 打开 文件 。 

(2) 从 文件 里 读 取 数 据 ， 或 者 向 文件 中 写 入 数据 。 

(3) 关闭 文件 。 

打开 文件 的 前 提 是 ， 文 件 首先 是 存在 的 。 如 果 不 存 在 ， 则 需要 建立 一 个 文件 。 并 且 在 所 
在 的 系统 环境 中 ， 代 码 应 该 对 文件 具有 “ 读 ” 或 “ 写 ” 的 权限 。 

以 下 示例 介绍 PHP 如 何 处 理 文件 数据 。 在 这 个 例子 中 ， 需 要 把 客人 订房 填写 的 信息 保存 
到 文件 中 ， 以 便 以 后 使 用 。 

【 例 10.1】( 示 例文 件 ch10\10.1.php 和 10.1.1.php) 

ED 在 与 PHP 文件 相同 的 目录 下 建立 一 个 文本 文件 ， 名 称 为 booked.txt; 然后 创建 

PHP 文件 10.1.php， 其 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1l/DTD/xhtmll-transitional.dtd"> 

<HTML xmlns="http://www.w3.0rg/1999/xhtml"> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h2>GoodHome 在 线 订房 表 (文件 储存 ) 。</h2> 
</HEAD> 
<BODY> 
<form action="10.2.php" method="post"> 
<table> 
<tr bgcolor="#3399FF"> 

<td> 客 户 姓名 :</td> 

<td><input type="text" name="customername" size="20" /></td> 
</tr> 
<tr bgcolor="#CCCCCC"> 

<td> 客 户 性 别 : </td> 

<td> 

<select name="gender"> 
<option value="m"> 男 </option> 
<option value="f"> 女 </option> 
</select> 

</td> 
</tr> 
<tr bgcolor="#3399FF"> 


加 


<td> 到 达 时 间 :</td> 
<td> 
<select name="arrivaltime"> 
<option value="1"> 一 天 后 </option> 
<option value="2"> 两 天 后 </option> 
<option value="3"> 三 天 后 </option> 
<option value="4"> 四 天 后 </option> 
<option value="5"> 五 天 后 </option> 
</select> 
</td> 
</tr> 
<tr bgcolor="#CCCCCC" > 
<td> 电 话 :</td> 
<td><input type="text" name="phone" size="20" /></td> 
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</tr> 
<tr bgcolor="#3399FF" > 

<td>email:</td> 

<td><input type="text" name="email" size="30" /></td> 
</tr> 


<tr bgcolor="#666666" > 
<td align="center"><input type="submit" value=" 确 认 订房 信息 " /></td> 
</tr> 
</table> 
</form> 
</BODY> 
</HTML> 


在 10.1.php 文件 的 相同 目录 下 创建 10.2.php 文件 ， 代 码 如 下 : 


<html> 

<head> 

<title> </title> 

</head> 

<body> 

<?php 

$DOCUMENT ROOT = $_ SERVER['DOCUMENT ROOT']; 
$customername = trim($ POST['customername']); 
$gender = $ POsST['gender']; 

$arrivaltime = $ POST['arrivaltime']7 
$phone = trim($ POST['phone']); 

$email = trim($ POST['email']); 


多 HG 


if($gender == "m"){ 
$customer = "先生 "; 

}jelsef 
$customer 


noes 


$date = date("H:i:s Y m d"); 
$string to be added = $date."\t".$customername."\t".$customer." 将 在 " 
.$arrivaltime."” 天 后 到 达 \t 联系 电话 : ".$phone."\t Email: ".$email ."\n"; 


二 
15@ 


PHP+ MySQL 动 态 网 站 开发 
案例 课堂 »… 


$fp = fopen("$DOCUMENT ROOT/booked.txt",'ab'); 
if (fwritel($fp, $string to be added, strlen($string to be added))){ 
echo $customername."\t".$customer 
." ,您 的 订房 信息 已 经 保存 。 我 们 会 通过 Email 和 电话 和 您 联系 。"; 
}elsef 
echo "信息 储存 出 现 错误 。"; 
. 
fclose ($fp); 
?> 
</body> 
</html> 


运行 10.1.php 文件 ， 最 终 效果 如 图 10-1 所 示 。 


人 Ge ez 有 -BCXx | 乱 localhost 


文件 (有 六 种 (FE) 下 看 (V) ”收藏 突 (A) 工具 (T) 帮助 (H) 


GoodHome 在 线 订 房 表 (文件 储 存 ) 。 


x 


Ea 


客户 址 名 5 

客户 性 别 。。 另 [] 
DEC 
电话 : 

ei 

[aa 


图 10-1 表单 效果 
ED 在 表单 中 输入 数据 ， 客 户 姓名 为 “ 李 莉 莉 ”、 到 达 时 间 为 “三 天 后 ”、 电 话 为 
“159XXXXX266”。 然 后 单 击 “ 确 认 订 房 信息 ”按钮 ， 浏 览 器 将 会 自动 跳 转 到 
formfilehandler.php 页 面 ， 并 且 同 时 会 把 数据 写 入 booked.txt 文件 。 如 果 先 前 没有 创 
建 booked.txt 文件 ，PHP 会 自动 创建 。 运 行 结果 如 图 10-2 所 示 。 


EE 


[¢ 回 贸 http:/loc. B 只 - BCX| Elocalhost x 


文件 (有 ” 蝙 名 (E) ”过 看 VM) 收 项 夫 (A) 工具 (T) 帮助 (H) 
李 草 莉 女士 ,您 的 订房 信息 已 经 保存 。 我 们 会 通过 Email 和 


电话 和 您 联系 


10-2 ”提交 后 的 结果 


连续 写 入 几 次 不 同 的 数据 ， 都 会 被 保存 到 booked.txt 中 。 用 写字 板 打 开 booked.txt， 运 行 
结果 如 图 10-3 所 示 。 


售 186 


| 


文件 (月 ” 蝙 铝 (E) 格式 (DO) 可 看 (V) 帮助 (H) 

06:23:16 2014 01 06 李 莉 莉 女士 将 在 3 天 后 到 达 电话 : 159XXXXX266 :+ 1ilili@hotnail. com 
06:25:41 2014 01 06 方芳 芳 女士 将 在 5 天 后 到 达 。 联 和 :136XXXXX253 : fangfangfang@hotmail. com 
06:26:26 2014 01 06 王小明 先生 将 在 2 天 后 到 达 电话 。 1359XXXXX377 : wangxiaoning@hotnail. com 
06:27:28 2014 01 06 起 大 勇 先生 将 在 4 天 后 到 达 E :1389XXXXX399 : zhaodayong@hotmail. com 


浏 下 灯 广 半 壮 注册 01 小 全 


笋 1 行 , 笋 4 列 


10-3 ”booked-txt 中 写 入 的 内 容 


案例 分 析 : 

(1) SDOCUMENT ROOT = $_SERVER[DOCUMENT ROOT’]:; 是 通过 使 用 全 局 数组 
$_SERVER 来 确定 本 系统 的 文件 根 目 录 。Windows 开发 环境 中 的 目录 是 C:/wamp/www/。 

(2) 其 中 的 $customername、S$arrivaltime、S$phone 是 form4file.html 通过 POST 方法 传递 给 
formfilehandler.php 的 数据 。 

(3) $date 为 用 date0 函 数 处 理 的 写 入 信息 时 的 系统 时 间 。 

(4) $string to_be_ added 是 要 写 入 booked.txt 文件 的 字符 串 数 据 。 它 的 格式 是 通过 “\t” 
和 “\n” 完 成 的 。“\t” 是 Tab; 而 “\n” 是 换 新 行 。 

(5) $fp = fopen(“$DOCUMENT_ROOT/booked.txt”,“ab’): 是 fopen0) 函 数 打开 文件 并 赋值 给 
变量 $ftp。fopen0 函数 的 格式 是 fopen(Path” “Parameter") 。 其 中 ，“$DOCUMENT 
ROOT/booked.txt" 就 是 路 径 (Patb)， 而 'ab' 是 参数 (ParameterD) 。'ab" 中 的 a 是 指 在 原 有 文件 上 继 
续 写 入 数据 ，b 则 是 规定 了 写 入 的 数据 是 二 进 制 (binary) 的 数据 模式 。 

(6) fwrite($fp, $string to be added, strlen($string to_be_added)); 是 对 已 经 打开 的 文件 进行 
写 入 操作 。strlen($string to_be_added) 是 通过 strlen0 函 数 给 出 所 要 写 入 字符 串 数据 的 长 度 。 

(7) 在 写 入 操作 完成 后 ， 用 fclose0 函 数 关 闭 文件 。 


10.1.2 文件 数据 的 读 取 


到 目前 为 止 ， 数据 已 经 写 入 到 了 文件 ， 而 且 文 件 也 可 以 直接 被 打开 ， 来 查看 数据 ， 并 对 
数据 进行 其 他 操作 。 但 是 ， 学 习 PHP 的 一 个 重要 目的 ， 是 要 完成 通过 浏览 器 对 数据 的 读 取 和 
使 用 。 那 么 ， 如 何 读 取 文件 中 的 数据 并 且 通 过 浏览 器 进行 展示 呢 ? 

下 面 的 例子 就 对 文件 数据 读 取 进 行 了 解 。 

【 例 10.2】( 示 例文 件 ch10\10.3.php) 


<html> 

<head> 

<title></title> 

</head> 

<body> 

<?php 

$DOCUMENT ROOT = $_ SERVER['DOCUMENT ROOT']; 
@$fp = fopen("$DOCUMENT ROOT/booked.txt",'rb'); 


IGG 
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if(!$fp){ 
echo "没有 订房 信息 。"; 
exit; 


3 

while (!feof ($fp)){ 
$order = fgets ($fp, 2048); 
echo $order. "<br />"; 

于 

fclose ($fp); 


esees 一 | 
SE |@ hoc.. BP- 8cx| locahost A 
文件 (六 名 (E) 查看 (V) ”收藏 天 (A) 工具 (T) 帮助 (H) 
06:23:16 2011 05 06 李 莉 莉 女士 将 在 3 天 后 到 达 联系 电话 159XXXXX266 Enail: 1ilili@hotnail. con 
06:25:41 2011 05 06 方芳 芳 女士 将 在 5 天 后 到 达 。 联系 电话 。 136XXXXX253 Enail: fangfangfang@hotmail. con 
2011 05 06 王小明 先生 将 在 2 天 后 到 达 联系 电话 ，1359XXXXX377 Enail: wangxiaoming@hotmail. con 


06:27:28 2011 05 06 赵 大 勇 先生 将 在 4 天 后 到 达 联系 电话 1389XXXXX399 Enail: zhaodayong@hotnail. com 


图 10-4 浏览 器 中 的 效果 


案例 分 析 : 

(1) SDOCUMENT_ROOT =$_SERVER['DOCUMENT ROOT']: 确 认 文 件 位 置 。 

(2) fopen0 通 过 参数 tb 打开 booked.txt 文件 ， 进 行 二 进 制 读 取 。 读 取 内 容 赋 值 给 变量 
$ftp。S$tp 前 的 @ 符 号 用 来 排除 错误 提示 。 

(3) 这 语句 表示 如 果 变 量 $fp 为 空 ， 则 显示 “没有 订房 信息 。” 且 退出 。 

(4) 在 while 循环 中 ，!feofS$fp) 表 示 只 要 不 到 文件 尾 ， 就 继续 while 循环 。 循 环 中 feets() 
读 取 变量 $fp 中 的 内 容 ， 并 赋值 给 Sorder。 

(5) fgets0 中 的 参数 2048 表示 允许 读 取 的 最 长 字 节 数 为 2048-1=2047 字 节 。 

(6) 最 后 用 fclose0 关 闭 文件 。 

不 管 是 读 文件 还 是 写 文件 ， 其 实在 用 fopen 打开 文件 的 时 候 就 确定 了 文件 模式 ， 即 打开 
某 个 特定 文件 是 用 来 做 什么 的 。fopen0 中 的 参数 表明 了 用 途 。 详 述 如 表 10-1 所 示 。 


表 10-1 fopen() 中 参数 的 用 途 


参 数 说 明 
¥ 打开 的 文件 用 于 读 取 ， 且 从 文件 头 开始 读 取 
革 打开 的 文件 用 于 读 取 和 写 入 ， 且 从 文件 头 开 始 读 取 和 写 入 
” 打开 的 文件 用 于 写 入 ， 且 从 文件 头 开始 写 入 。 如 果 文 件 已 经 存 


在 ， 则 清空 原 有 内 容 ， 如 果 文 件 不 存在 ， 则 创建 此 文件 


地 


第 
续 表 己 
参 数 意 义 说 明 3 
a 写 入 打开 的 文件 用 于 写 入 和 读 取 ， 且 从 文件 头 开始 写 入 。 如 果 文 件 已 经 可 
存在 ， 则 清空 原 有 的 内 容 ， 如 果 文 件 不 存在 ， 则 创建 此 文件 入 
, 谨慎 写 入 打开 的 文件 用 于 写 入 ， 且 从 文件 头 开始 写 入 。 如 果 文 件 已 经 存在 ， 是 
则 不 会 被 打开 ， 同 时 fopen 返回 false， 且 PHP 生成 警告 录 

Se 谨慎 写 入 打开 的 文件 用 于 写 入 和 读 取 ， 且 从 文件 头 开始 写 入 。 如 果 文 件 已 经 

存在 ， 则 不 会 被 打开 ， 同 时 fopen 返回 false， 且 PHP 生成 警告 
， 添加 打开 的 文件 仅 用 于 添加 写 入 ， 且 在 已 存在 内 容 之 后 写 入 。 如 果 文 件 


不 存在 ， 则 创建 此 文件 


at 


打开 的 文件 用 于 添加 写 入 和 读 取 ， 且 在 已 存在 内 容 之 后 写 入 。 如 果 
文件 不 存在 ， 则 创建 此 文件 


配合 以 上 的 不 同 参数 使 用 。 二 进 制 文件 模式 不 管 是 在 Linux 还 是 
Windows 下 都 是 可 使 用 的 。 一 般 情况 下 ， 都 选择 二 进 制 模 式 
文本 模式 只 能 在 Windows 下 被 使 用 


二 进 制 (binary) 


文本 (text) 


多 A 


10.2 目录 操作 


在 PHP 中 ,利用 相关 函数 可 以 实现 对 目录 的 操作 。 常 见 的 目录 操作 函数 使 用 方法 和 技巧 


如 下 。 


1. string getcwd(void) 


该 函数 主要 是 获取 当前 的 工作 目录 ， 返 回 的 是 字符 串 。 下 面 举 例 说 明 此 函数 的 用 法 。 
【 例 10.3】( 示 例文 件 ch10\10.4.php) 


<html> 
<head> 
<title> 获 取 当 前 工作 目录 </title> 
</head> 
<body> 
<?php 
$d1 = getcwd(); // 获 取 当 前 路 径 
echo getcwd(); // 输 出 当前 目录 


运行 结果 如 图 10-5 所 示 。 
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C:\php5. 5\chll 


10-5 获取 当前 的 工作 目录 
2. array scandir(string directory[, int sorting_order]) 


该 函数 返回 一 个 array， 包 含有 directory 中 的 文件 和 目录 。 如 果 directory 不 是 一 个 目录 ， 
则 返回 布尔 值 FALSE， 并 产生 一 条 E_ WARNING 级 别 的 错误 。 默 认 情 况 下 ， 返 回 值 是 按照 
字母 顺序 升序 排列 的 。 如 果 使 用 了 可 选 参数 sorting_order( 设 为 )， 则 按 字母 顺序 降序 排列 。 

下 面 举例 说 明 此 函数 的 使 用 方法 。 

【 例 10.4】( 示 例文 件 ch10\10.5.php) 


<html> 

<head> 

<title> 获取 当前 工作 目录 中 的 文件 和 目录 </title> 
</head> 

<body> 

<?php 

$dir = 'd:/ch10'; ”// 定 义 指定 的 目录 

$filesl = scandir ($dir); // 列 出 指定 目录 中 文件 和 目录 
$files2 = scandir($dir, 1); 

print r($files1);  // 输 出 指定 目录 中 的 文件 和 目录 
print r($files2); 

Ee 

</body> 

</html> 


运行 结果 如 图 10-6 所 示 。 


¢ SE ra ER 


Array ( [0] => . [1] => .. [2] => booked. txt ) Array ( [0] => 
booked. txt [1] => .. [2] => . ) 


10-6 使 用 array scandir 函数 


El 


3. dir(sting directory) 
此 函数 模仿 面向 对 象 机 制 ， 将 指定 的 目录 名 转换 为 一 个 对 象 并 返回 。 使 用 说 明 如 下 : 


class dir { 
Qir (string directory) 
string path 
resource handle 
string read(void) 
void rewind(void) 
void close (void) 


其 中 handle 属性 含义 为 目录 句柄 ，path 属性 的 含义 为 打开 目录 的 路 径 ， 函 数 read(void) 的 
含义 为 读 取 目 录 ， 函 数 rewind(void) 的 含义 为 复位 目录 、 函 数 close(void) 的 含义 为 关闭 目录 。 

下 面 举例 说 明 此 函数 的 使 用 方法 。 

【 例 10.5】( 示 例文 件 ch10\10.6.php) 


<html> 

<head> 

<title> 将 目录 转换 为 对 象 </title> 

</head> 

<body> 

<?php 

$a2 = dir("d: /ehLlon)s 

echo "Handle: ".$d2->handle."<br>\n"; 

echo "Path: ".$d2->path."<br>\n"; 

while (false !== ($entry = $d2->read())) { 
echo $entry."<br>\n"; 

3 

$d2->close(); 


Eee 

</body> 

</html> 

运行 结果 如 图 10-7 所 示 。 


| 文件 (有) ” 妨 铝 (E) 坦 看 (V) ”收藏 夫 (A) 工具 (T) ”帮助 (H) 


Handle: Resource id #3 
Path: d:/chll 


booked. txt 


图 10-7 使 用 dir 函数 
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4. chdir(string directory) 


此 函数 将 PHP 的 当前 目录 改 为 directory。 如 果 成 功 则 返回 TRUE， 失 败 则 返回 FALSE。 
下 面 举例 说 明 此 函数 的 使 用 方法 。 
【 例 10.6】( 示 例文 件 ch10\10.7.php) 


<html> 
<head> 
<title> 将 当前 目录 修改 为 directory</title> 
</head> 
<body> 
<?php 
if(chdir("d:/ch11")){ 
echo "当前 目录 更 改 为 : d: /chll<br>"; 
jelsei 


echo "当前 目录 更 改 失 败 了 "; 


} 

六 
</body> 
</html> 


运行 结果 如 图 10-8 所 示 。 


名 htp//loc. 力 P - 昌 C X | 合格 当前 目录 局 改 direc，x 
文件 (站 坊 纺 (和) 豆 看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


| 当前 目录 更 改 为 : d: /chll 


成 100% ~ 


10-8 使 用 chdir 函数 
5. void closedir(resource dir handle) 
此 函数 主要 是 关闭 由 dir_handle 指定 的 目录 流 ， 另 外 ， 目 录 流 必须 已 经 被 opendir0 打 开 。 
6. resource opendir(string path) 


返回 一 个 目录 句柄 。 其 中 path 为 要 打开 的 目录 路 径 。 如 果 path 不 是 一 个 合法 的 目录 或 者 
因为 权限 限制 或 文件 系统 错误 而 不 能 打开 目录 ， 返 回 FALSE 并 产生 一 个 E WARNING 级 别 
的 PHP 错误 信息 。 如 果 不 想 输出 错误 ， 可 以 在 opendir0 前 面 加 上 @ 符 号 。 

【 例 10.7】( 示 例文 件 ch10\10.8.php) 


<html> 

<head> 
<title></title> 
</head> 


全" 


<body> 
<?php 
sdir = "r/chLoO/ 
// 打 开 一 个 目录 ， 然 后 读 取 目 录 中 的 内 容 
3f (is dir(sair}} { 
if ($dh = opendir($dir)) { 
while (($file = readdir($dh)) !== false) { 
Pirint “filename, Hiile Ss Filetype ™ 
- filetype(Sdir < $file) » "Ni 
} 
closedir ($dh); 


filename: . : filetype: dir filename: 

: filetype: dir filename: 
11.3.php : filetype: file filename: 
11.4.php : filetype: file filename: 
11. 5. php : filetype: file 


图 10-9 使 用 opendir 函数 


其 中 ，is_dir0 函 数 主要 是 判断 给 定 文件 名 是 否 是 一 个 目录 ，readdir0) 函 数 从 目录 句柄 中 读 
取 条 目 ，closedir0 函 数 关 闭 目 录 句 柄 。 


7. string readdir(resource dir_ handle) 


该 函数 主要 是 返回 目录 中 下 一 个 文件 的 文件 名 。 文 件 名 以 在 文件 系统 中 的 排序 返回 。 
【 例 10.8】( 示 例文 件 ch10\10.9.php) 


<html> 

<head> 

<title></title> 

</head> 

<body> 

<?php 

// 注 意 在 4.0.0-RC2 之 前 不 存在 !== 运算 符 

if ($handle = opendir('d:/ch10')) { 
echo "Directory handle: $handle\n™; 
echo "Files:\n"; 
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/* 这 是 正确 的 遍历 目录 方法 */ 
while (false !== ($file = readdir($handle))) { 
echo "$file\n™"; 
} 
closedir($handle); 
</body> 
</html> 


运行 结果 如 图 10-10 所 示 。 


合 E 车 hapyoc- @ P - BCx| Gocahos 
文 伯 肯 ”如 (6 查看) 收藏 只 A】 工具 (帮助 H) 


| 
Directory handle: Resource id #2 Files: 
. 12. 3. php 12. 4. php 12. 5. php 


图 10-10 使 用 readdir 函数 


在 遍历 目录 时 ， 有 的 人 经 常会 写 出 如 下 错误 的 遍历 方法 : 


/* 这 是 错误 的 遍历 目录 的 方法 */ 

while ($file = readdir($handle)) { 
echo "$file\n"; 

} 


10.3 上 传 文件 


在 网 络 上 ， 用 户 可 以 上 传 自己 的 文件 。 实 现 这 种 功能 的 方法 很 多 ， 用 户 把 一 个 文件 上 传 
到 服务 器 ， 需 要 在 客户 端 和 服务 器 端 建立 一 个 通道 来 传递 文件 的 字 节 流 ， 并 在 服务 器 进行 上 
传 操作 。 下 面 介 绍 一 种 使 用 代码 最 少 ， 并 且 容 易 理 解 的 方法 。 

【 例 10.9】( 示 例文 件 ch10\10.10.1php 和 10.10.php) 

ED 首先 创建 一 个 实现 文件 上 传 功能 的 文件 。 为 了 设置 和 保存 上 传 文件 的 路 径 ， 用 

户 需 要 在 创建 文件 的 目录 下 新 建 一 个 名 称 为 “file” 的 文件 夹 。 然 后 新 建 10.10.1.php 
文件 ， 代 码 如 下 : 

<html> 

<head> 

<title> 实 现 上 传 文件 </title> 


</head> 
<body> 


各 


<?php 
if ($_POST[add]==" 上 传 ") { 
// 根 据 现在 的 时 间 产 生 一 个 随机 数 
$randl = rand(0,9); 
$rand2 = rand(0,9); 
$rand3 rand(0,9); 
$filename = date("Ymdhms").$randl.$rand2.s$rand3; 
if(empty($ FILES['file name']['name']))1{ 
//$ FILES['file name']['name'] 获 取 客 户 端 机 器 文件 的 原名 称 
echo "文件 名 不 能 为 空 "; 


exit; 


外 


涛 严 灯 让 半 佐 注册 01 中 便 


} 
$oldfilename = $ FILES['file name']['name']; 
echo "<br> 原 文件 名 为 : ".$oldfilename; 
$filetype = substr($oldfilename,strrpos ($oldfilenamev".")， 
strlen($oldfilename)-strrpos ($0oldfilename,".")); 
echo "<br> 原 文件 的 类 型 为 : " . $filetype; 
if(($filetype!='.doc')&& ($filetype!=' .xls')&& ($filetype!="' .DOC') 
&& ($filetype!="' .XLS')){ 

echo "<script>alert (' 文 件 类 型 或 地 址 错误 ') ;</script>"; 

echo "<script>location.href='10.3.php';</script>"; 

exit; 


IGG 


} 
echo "<br> 上 传 文件 的 大 小 为 ( 字 节 ) : ".$_FILES['file name']['size']; 
//$_FILES['file_name']['size'] 获 取 客 户 端 机 器 文件 的 大 小 ， 单 位 为 B 
if ($_ FILES['file name'] ['size']>1000000) { 
echo "<script>alert (' 文 件 太 大 ， 不 能 上 传 ') ;</script>"; 
echo "<script>location.href='10.3.php';</script>"; 
exit; 
} 
echo "<br> 文 件 上 传 服务 器 后 的 临时 文件 名 为 : ".$_FILES['file name']['tmp_name']; 
// 取 得 保存 文件 的 临时 文件 名 ( 含 路 径 ) 
$filename = $filename.$filetype; 
echo "<br> 新 文件 名 为 : ". $filename; 
$savedir = "file/".$filename; 
if(move uploaded file($ FILES['file name']['tmp name'],$savedir)){ 


$file name = basename ($savedir); // 取 得 保存 文件 的 文件 名 (不 含 路 径 ) 
echo "<br> 文 件 上 传 成 功 ! 保存 为 : " .$savedir; 
}elsef{ 


echo "<script language=javascript>"; 

echo "alert (' 错 误 ， 无 法 将 附件 写 入 服务 器 !\n 本 次 发 布 失败 ! ') ; "; 
echo "location.href='10.3.php?2';7"; 

echo "</script>"; 

exit; 


人 
</body> 
</html> 
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代码 分 析 如 下 。 

(1) 需要 首先 创建 变量 ， 设 定 文件 的 上 传 类 型 、 保 存 路 径 和 程序 所 在 路 径 。 

(2) 实现 自 定义 函数 ， 获 取 文件 后 缀 名 和 生成 随机 文件 名 。 在 上 传 过 程 中 ， 如 果 上 传 了 
大 量 的 文件 ， 可 能 会 出 现 文件 名 称 重复 的 现象 ， 所 以 本 例 在 文件 上 传 的 过 程 中 ， 首 先 获取 上 
传 文件 的 后 缀 名 称 并 结合 随机 产生 的 数值 生成 一 个 新 的 文件 ， 避 免 了 文件 名 重复 的 现象 。 

(3) 判断 获取 的 文件 类 型 是 否 符合 指定 类 型 ， 如 果 符 合 ， 则 给 该 文件 生成 一 个 具有 随机 
性 质 的 名 称 ， 并 使 用 move_uploaded file 函数 完成 文件 的 上 传 ， 否 则 显示 提示 信息 。 

ERP 下 面 创 建 一 个 获取 上 传 文件 的 页 面 ， 文 件 名 为 10.10.php， 代 码 如 下 : 


<html> 
<head><title> 上 传 文件 </title></head> 
<h3 align="center"> 上 传 文件 </h3> 
<form method="post" action="10.10.1.php" enctype="multipart/form-data"> 
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%"> 
二 
<td height="16"> 
<input name="file" type="file" value=" 浏 览 ” /> 
<input type="submit" value=" 上 传 " name="B1l" /> 
</td> 
</tr> 
</table> 
</form> 
</body> 
</html> 


其 中 <form method=“post”action=“10.10.1.php”enctype=“multipart/form-data”> 语 句 中 的 
method 属性 表示 提交 信息 的 方式 是 post， 即 采用 数据 块 ，action 属性 表示 处 理 信息 的 页 面 为 
10.10.1.php，ENCTYPE=“multipart/form-data” 表 示 以 二 进 制 的 方式 传递 提交 的 数据 。 

运行 结果 如 图 10-11 所 示 。 单 击 “ 浏 览 ” 按 钮 ， 即 可 选择 需要 上 传 的 文件 ， 最 后 单 击 
“上 传 ”按钮 ， 即 可 实现 上 传 操作 。 


碟 htpyiloc- 中 DD-B0x 


文件 (月 ”六 句 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


图 10-11 上 传 文件 
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10.4 ”编写 访客 计数 器 


下 面 通过 对 文本 文件 的 操作 ， 利 用 相关 函数 编写 一 个 简单 的 文本 类 型 的 访客 计数 器 。 
【 例 10.10】( 示 例文 件 ch10\10.11.php) 


<html> 

<head> 
<title> 访 客 计数 器 </title> 

</head> 

<body> 

<?php 

if (!@$fp=fopen ("coun.txt","r")){ // 以 只 读 方式 打开 coun .txt 文件 
echo "coun .txt 文件 创建 成 功 ! <br>"; 

， 

@$num = fgets ($fp,12);  // 读 取 11 位 数字 

if ($num=="") $num=0; // 如 果 文件 的 内 容 为 空 ， 初 始 化 为 0 

Snurm++7 // 浏 览 次 数 加 1 

@fclose ($fp); // 关 闭 文件 

$fp = fopen("coun.txt"，"w")7 // 以 只 写 方式 打开 coun .txt 文件 

fwrite ($fp, $num); ”// 写 入 加 1 后 的 结果 

fclose ($fp); // 关 闭 文件 

echo "您 是 第 " .Snum." 位 浏览 者 !"; // 浏 览 器 输出 浏览 次 数 

名 六 

</body> 

</html> 


程序 第 一 次 运行 时 ， 结 果 如 图 10-12 所 示 。 
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文件 (F) ”编辑 (E) 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


coun, txt 文 件 创建 成 功 ! 
您 是 第 1 位 浏览 者 ! 


图 10-12 ”程序 第 一 次 运行 的 效果 


由 结果 可 以 看 出 ， 该 程序 首先 创建 了 一 个 count.txt 文本 文件 ， 用 于 保存 浏览 次 数 ， 接 
着 ， 打 开 这 个 文件 ， 将 数据 初始 化 为 0， 并 实现 加 1 操作 。 
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10.5 疑难 解 惑 


疑问 1: 如 何 批量 上 传 多 个 文件 ? 
本 章 讲述 了 如 何 上 传单 个 文件 ， 那 么 如 何 上 传 多 个 文件 呢 ? 用 户 只 需要 在 表单 中 使 用 复 


选 框 相同 的 数组 式 提交 语法 即 可 。 
提交 的 表单 语句 如 下 : 
<form method="post" action="10.3.1.php" enctype="multipart/form-data"> 
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%"> 
<tr> 
<td> 
<input name="userfile[]" type="file" value=" 浏 览 1" /> 
<input name="userfile[]" type="file" value=" 浏 览 2" /> 
<input name="userfile[]" type="file"™" value=" 浏 览 3" /> 
<input type="submit" value=" 上 传 " name="B1l" /> 
</td> 
</tr> 
</table> 
</form> 


疑问 2: 如 何 从 文件 中 读 取 一 行 ? 


在 PHP 网 站 开发 中 ， 支 持 从 文件 指针 中 读 取 一 行 。 使 用 string fgets(int handle[,int length]) 
函数 即 可 实现 上 述 功能 。 其 中 int handle 是 要 读 入 数据 的 文件 流 指针 ， 由 fopen0 函 数 返回 数 
值 ，int length 设置 读 取 的 字符 个 数 ， 读 入 的 字符 个 数 为 length-1。 如 果 没 有 指定 length， 则 默 
认为 1024 个 字 节 。 
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PHP 是 一 种 专门 设计 用 于 Web 开发 的 服务 器 端 脚本 语言 。 从 这 个 描述 可 以 知 
道 ，PHP 要 打交道 的 对 象 主要 有 服务 器 (Server) 和 基于 Web 的 HTML( 超 文本 标识 语 
言 )。 使 用 PHP 处 理 Web 应 用 时 ， 需 要 把 PHP 代码 嵌入 到 HTML 文件 中 。 每 次 当 
这 个 HTML 网 页 被 访问 的 时 候 ， 其 中 嵌入 的 PHP 代码 就 会 被 执行 ， 并 且 返 回 给 请 
求 浏览 器 已 生成 好 的 HIML。 换 句 话 说， 在 上 述 过 程 中 ，PHP 就 是 用 来 执行 且 生 成 
HTML 的 。 本 章 主要 讲述 PHP 与 Web 页 面 的 交互 操作 技术 。 
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11.1 创建 动态 内 容 


为 什么 要 使 用 动态 内 容 呢 ? 因为 动态 内 容 可 以 给 网 站 使 用 者 不 同 的 和 实时 变化 的 内 容 。 
极 大 地 提高 了 网 站 的 可 用 性 。 如 果 Web 应 用 都 只 是 使 用 静态 内 容 ， 则 Web 编程 就 完全 不 用 
引入 PHP、JSP 和 ASP 等 服务 器 端 脚本 语言 了 。 通 俗 地 说 ， 使 用 PHP 语言 的 主要 原因 之 一 ， 
就 是 要 产生 动态 内 容 。 

下 面 进 行使 用 动态 内 容 案例 的 讲解 。 此 例 中 ， 在 先 不 涉及 变量 和 数据 类 型 的 情况 下 ， 仅 
使 用 PHP 中 的 一 个 内 置 函数 来 获得 动态 内 容 。 此 动态 内 容 就 是 使 用 date0 函 数 获 得 Web 服务 
器 的 时 间 。 

【 例 11.1】( 示 例文 件 chll\11.1.php) 


<HTML> 

<HEAD><h2>PHP Tells time. - PHP 告诉 我 们 时 间 。</h2></HEAD> 
<BODY> 

<?php 

date default timezone set ("PRC"); 

echo "现在 的 时 间 为 : "; 

echo date("H:i:s Y m d"); 

x 

</BODY> 

</HTML> 


运行 结果 如 图 11-1 所 示 。 
过 一 段 时 间 ， 再 次 运行 上 述 PHP 页 面 ， 即 可 看 到 显示 的 内 容 发 生 了 动态 变化 ， 如 图 11-2 


所 示 。 

【¢ Er Pp Box)Glocalhost x “eo 【¢ 问 全 tp/loc. @ P BOX| Glocalhost x 
文件 (站 编 (E) 喜 看 VM) 收 训 交 () 工具 (T) 帮助 (H) 文件 (| 并 星 四 二 看 V) 收藏 夫人 工具 (T) 帮助 (H) 
PHP Tells time.- PHP 告 诉 我 们 时 间 。 Ee Tells time.- PHP 告 诉 我 们 时 间 。 
现在 的 时 间 为 ，12:51:32 2014 04 30 | 现在 的 时 间 为 ，12:52:17 2014 04 30 

胞 100% ~ | 有 100% ~ 
图 11-1 初始 结果 图 11-2 时 间 发 生 了 变化 
案例 分 析 : 


(1) 页 面 上 的 “PHP Tells time. - PHP 告诉 我 们 时 间 。” 是 HTML 中 的 <HEAD><h2>PHP 
Tells time. - PHP 告诉 我 们 时 间 。</h2></HEAD> 所 生成 的 。 后 面 的 “现在 的 时 间 为 : 
12:51:32 2014 04 30” 是 由 <?php echo “现在 的 时 间 为 : ”; echo date(“H:i:s Y m d”); ?> 生成 的 。 
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(2) 由 于 “现在 的 时 间 为 : 12:51:32 2014 04 30” 是 由 dateO) 函 数 动态 生成 并 且 实时 更 新 
的 ， 所 以 再 次 打开 或 刷新 此 文件 的 时 候 ，PHP 代码 再 次 执行 ， 所 输出 的 时 间 也 发 生 改 变 。 

(3) 此 实验 中 ， 通 过 date0 函 数 处 理 系 统 时 间 ， 得 到 动态 内 容 。 时 间 处 理 是 PHP 中 的 一 
项 重要 的 功能 。 


11.2 ”表单 与 PHP 


不 管 是 一 般 的 企业 网 站 还 是 复杂 的 网 络 应 用 ， 都 离 不 开 数据 的 添加 。 通 过 PHP 服务 器 端 
脚本 语言 ， 程 序 可 以 处 理 那些 通过 浏览 器 对 Web 应 用 进行 数据 调用 或 添加 的 请 求 。 

回忆 一 下 平常 使 用 的 网 站 数据 输入 功能 ， 不 管 是 Web 邮箱 ， 还 是 QQ 留言 ， 都 经 常 要 填 
写 一 些 表格 ， 再 由 这 些 表格 把 数据 发 送出 去 。 而 完成 这 个 工作 的 部 件 就 是 “表单 (form)”。 

虽然 表单 (form) 是 HTML 语言 中 的 东西 ， 但 是 PHP 与 form 变量 的 衔接 是 无 颖 的 。PHP 
关心 的 是 怎样 获得 和 使 用 form 中 的 数据 。PHP 功能 强大 ， 可 以 轻松 地 对 表单 进行 处 理 。 

处 理 表单 数据 的 基本 过 程 是 ， 数据 从 Web 表单 (form) 发 送 到 PHP 代码 ， 经 过 处 理 ， 再 生 
成 HTML 输出 。 它 的 处 理 原 理 是 : 当 PHP 处 理 一 个 页 面 的 时 候 ， 会 检查 URL、 表 单数 据 、 
上 传 文件 、 可 用 cookie、Web 服务 器 和 环境 变量 。 如 果 有 可 用 信息 ， 就 可 以 通过 PHP 访问 自 
动 全 局 变量 数组 $ GET、$_POST、$_FILES、$_COOKIE、$_SERVER、$_ENV 得 到 。 


11.3 ”设计 表单 元 素 


表单 是 一 个 比较 特殊 的 组 件 。 在 HTML 中 有 着 比较 特殊 的 功能 和 结构 。 下 面 了 解 一 下 表 
单 的 一 些 基本 元 素 。 


11.3.1 表单 的 基本 结构 
表单 的 基本 结构 是 由 <formm></form> 标 识 包 庄 的 区 域 。 例 如 : 


<HTML> 
<HEAD> 
</HEAD> 
<BODY> 
<form action=" " method=" " enctype=" "> 


ns 

</BODY> 

</HTML> 

其 中 ，<form> 标 识 内 必须 包含 属性 。action 指定 数据 所 要 发 送 到 的 对 象 文件 。method 指 
定数 据 传 输 的 方式 。 

如 果 在 上 传 文件 等 操作 时 ， 还 要 定义 enctype 属性 ， 来 指定 数据 类 型 。 
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11.3.2 文本 框 


文本 框 是 form 输入 框 中 最 为 常见 的 一 个 。 下 面 通过 例子 来 讲述 文本 框 的 使 用 方法 。 

具体 操作 如 下 。 

在 网 站 根 目录 下 创建 phpform 文件 夹 ， 然 后 再 其 下 创建 文件 formdemo.html， 代 
码 如 下 : 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 
<h3> 输 入 一 个 信息 (比如 名 称 ) : </h3> 


N <input type="text" name="name" size="10" /> 


</form> 
</BODY> 
</HTML> 


加 7Y 在 phpform 文件 夹 下 创建 文件 formdemohandler.php， 代 码 如 下 : 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<?php 

Sname = $ POST['name']; 
echo $name; 

人 

</BODY> 

</HTML> 


运行 formdemo.html， 结 果 如 图 11-3 所 示 。 
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输入 一 个 信息 《比如 名 称 ) : 


11-3 ”使 用 文本 杠 


案例 分 析 : 
(1) <input type=“text” name=“name”size=“10”/> 语 句 定义 了 form 的 文本 框 。 定 义 一 个 输 
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入 框 为 文本 框 的 必要 因素 为 : 
<input type="text" ... /> 


这 样 就 定义 了 一 个 文本 框 ， 其 他 的 属性 则 如 例 中 一 样 ， 可 以 定义 文本 框 的 name 属性 ， 以 
确认 此 文本 框 的 唯一 性 ， 定 义 size 属性 以 确认 此 文本 框 的 长 度 。 
(2) 在 formdemohandler.php 文件 中 ， 则 使 用 了 文本 框 的 name 值 “name”。 


11.3.3” 复 选 框 


复 选 框 可 用 于 选择 一 项 或 者 多 项 。 通 过 修改 formdemo 的 例子 加 以 说 明 。 具 体操 作 如 下 。 
在 phpform 文件 夹 下 修改 文件 formdemo.html 为 如 下 代码 : 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 
<h3> 输 入 一 个 信息 (比如 名 称 ) : </h3> 
<input type="text" name="name" size="10" /> 
<h3> 确 认 此 项 (可 复 选 ): </h3> 
<input type="checkbox" name="achecked" checked="checked" value="1" /> 
选择 此 项 传递 的 A 项 的 value 值 。 
<input type="checkbox" name="bchecked" value="2" /> 
选择 此 项 传递 的 B 项 的 value 值 。 
<input type="checkbox" name="cchecked" value="3" /> 
选择 此 项 传递 的 c 项 的 value 值 。 

</form> 

</BODY> 

</HTML> 


在 phpform 文件 夹 下 修改 文件 formdemohandler.php， 其 代码 如 下 : 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<?php 

Sname = $ POST['name']; 

if(isset($ POST['achecked'])){ 
$achecked = $ POsT['achecked']; 

if(isset($ POST['bchecked'])){ 
$bchecked = $ _ POST['bchecked']; 

. 

if(isset($ POST['cchecked']))1{ 
$cchecked = $ POST['cchecked']; 

$aradio = $ POST['aradio']7 

$aselect = $ POST['aselect']7 


癌 准 副 洒 qeMT 山上 | 名 DD 


py A 


echo $name."<br />"; 
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案例 课堂 > 
if(isset($achecked) and $achecked == 1)1{ 
echo "选项 A 的 value 值 已 经 被 正确 传递 。<br />"; 


jelsef 

echo "选项 A 没有 被 选择 ， 其 value 值 没 有 被 传递 。<br />"; 
if(isset($bchecked) and $bchecked == 2){ 

echo "选项 B 的 value 值 已 经 被 正确 传递 。<br />"; 
}else{ 


echo "选项 B 没有 被 选择 ， 其 value 值 没 有 被 传递 。<br />"; 


} 


if(isset($cchecked) and $cchecked == 3){ 
echo "选项 c 的 value 值 已 经 被 正确 传递 。<br />"; 
}else{ 


echo "选项 c 没有 被 选择 ， 其 value 值 没有 被 传递 。<br />"; 
} 
?> 
</BODY> 
</HTML> 


运行 formdemo.html， 结 果 如 图 11-4 所 示 。 


Oe 3- scx] eonos x eee 


文件 (F) ”入 独 (E) 前 看 (V) 收藏 交 (A) 工具 (T) 帮助 (H) 


输入 一 个 信息 《比如 名 称 》: 
确认 此 项 (可 复 选 》: 


回 选择 此 项 传递 的 A 项 的 value 值 。 口 选择 此 项 传递 的 B 项 的 value 值 。 
口 选择 此 项 传递 的 C 项 的 value 值 。 


区 100% ~ 


图 11-4 使 用 复 选 框 
案例 分 析 : 


(1) <input type=“checkbox” name="“inputchecked”checked=“checked”value=“1”/> 语 句 定 
义 了 复 选 框 。 定 义 一 个 input 标识 为 复 选 框 时 需 指定 类 型 为 checkbox: 


<input type="checkbox" ... /> 


定义 为 复 选 框 之 后 ， 还 需要 定义 复 选 框 的 name 属性 ， 以 确定 在 服务 器 端 程序 的 唯一 性 ; 
定义 value 属性 ， 以 确定 此 单 选项 所 要 传递 的 值 ， 定 义 checked 属性 ， 以 确定 复 选 框 的 默认 状 
态 ， 若 为 checked， 则 是 默认 为 选中 ， 如 果 不 定义 此 项 ， 默 认 情况 下 为 不 选中 。 

(2) formdemohandler.php 文件 中 ， 使 用 的 选项 name 值 为 achecked、bchecked、cchecked 
并 根据 value 值 做 出 判断 。 
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11.3.4 ” 单 选 按 钮 


下 面 通过 案例 来 介绍 如 何 使 用 单 选 按 钮 ， 仍 然 通 过 修改 formdemo 的 例子 加 以 说 明 ， 具 体 
步骤 如 下 。 
在 phpform 文件 夹 下 修改 formdemo.html 文件 ， 代 码 如 下 : 


<HTML> 

<HEAD> 

</HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 


问 准 副 测 qaMJT 翰 上 1 溃 捍 


<h3> 单 选 一 项 : </h3> 
<input type="radio" name="aradio” value="al"” /> 蓝天 
<input type="radio" name="aradio"” value="a2" checked="checked" /> 白云 
<input type="radio" name="aradio" value="a3" /> 大 海 
</form> 
</BODY> 
</HTML> 


在 phpform 文件 夹 下 修改 formdemohandler.php 文件 ， 代 码 如 下 : 


<HTML> 
<HEAD> 
</HEAD> 
<BODY> 
<?php 


多 A 


$aradio = $ POsST['aradio']; 
echo $name; 


if(isset($achecked) and $cchecked == 3){ 
echo "选项 c 的 value 值 已 经 被 正确 传递 。<br />"; 
}else{ 
echo "选项 c 没有 被 选择 ， 其 value 值 没有 被 传递 。<br />"; 
if($aradio == "al'9){ 
echo "蓝天 "; 
}else if($aradio == "a2'){ 
echo "白云 "; 
}elsef 
echo "大 海 "; 
?2> 
</BODY> 
</HTML> 


运行 formdemo.html， 结 果 如 图 11-5 所 示 。 
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大 hapyoc- 儿 P- SOX localhost x Ce 
文件 ( 朋 ” 演 和 (查看 (V) 。 收 生 夫 (A) 工具 (帮助 (H) 
输入 一 个 信息 《比如 名 称 》: 
C |] 
确认 此 项 (可 复 选 》: 


选择 此 项 传递 的 A 项 的 value 值 。 口 选择 此 项 传递 的 B 项 的 value 值 。 
口 选择 此 项 传递 的 C 项 的 value 值 。 


单 选 一 项 : 
〇 蓝天 @ 白 云 O 大 海 


11-5 ”使 用 单 选 按钮 


案例 分 析 : 

(1) <input type="“radio”name=“aradio”value=“al”/> 语 句 定义 了 一 个 单 选 按钮 。 后 面 的 
<input type=“radio” name="“aradio” value="“a2” checked=“checked”/> 和 <input type=“radio” 
name=“aradio”value=“a3”/> 定 义 了 另外 的 两 个 单 选 按钮 。 

定义 一 个 input 标识 为 单 选 按 钮 时 需 指定 类 型 为 radio: 


<input type="radio" ... /> 


定义 为 单 选 按钮 后 ， 还 需要 定义 单 选 按 钮 的 name 属性 ， 以 确定 在 服务 器 端 程序 的 唯一 
性 ;定义 value 属性 ， 以 确定 此 单 选 按钮 所 要 传递 的 值 ， 定 义 checked 属性 ， 以 确定 单 选 按钮 
的 默认 状态 ， 若 为 checked 则 是 默认 的 选择 ， 如 果 不 定义 此 项 ， 默 认 情 况 下 为 不 选择 。 

(2) 在 formdemohandler.php 文件 中 ， 使 用 了 单 选 按钮 的 name 值 为 “aradio”。 然 后 让 语 
句 通过 对 aradio 传递 的 不 同 值 做 出 判断 ， 打 印 不 同 的 值 。 


11.3.5 下 拉 列 表 


下 面 通过 案例 来 介绍 下 拉 列 表 的 使 用 方法 和 技巧 。 仍 然 通过 修改 formdemo 的 例子 加 以 说 
明 。 具 体操 作 如 下 。 
在 phpform 文件 夹 下 修改 formdemo.html 文件 ， 添 加 代码 如 下 : 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 


<h3> 在 下 拉 菜 单 中 一 项 : </h3> 
<select name="aselect" size="]1"> 
<option value="hainan"> 海 南 </option> 
<option value="qingdao” selected> 青 岛 </option> 
<option value="beijing"> 北 京 </option> 
<option value="xizang"> 西 藏 </option> 
</select> 


</form> 
</BODY> 
</HTML> 


在 phpform 文件 夹 下 修改 formdemohandler.php 文件 ， 代 码 如 下 : 


<HTML> 
<HEAD></HEAD> 
<BODY> 

<?php 


$aselect = $ POsT['aselect']; 
echo $name."<br />"; 


J}else{ 
echo "大 海 "; 
} 
if($aselect == 'hainan'){ 
echo "海南 "; 
Jelse if($aselect == 'gqingdao'){ 
echo "青岛 "; 
}jelse if($aselect == 'beijing'){ 
echo "北京 "; 
}elsef{ 
echo "西藏 "; 
} 
i 
</BODY> 
</HTML> 


运行 formdemo.html， 结 果 如 图 11-6 所 示 。 


Geass | 


输入 一 个 信息 《比如 名 称 ) : 


确认 此 项 《可 复 选 》: 


回 选择 此 项 传递 的 A 顶 的 value 值 。 口 选择 此 项 传递 的 B 项 的 value 值 , 
口 选择 此 项 传递 的 C 项 的 value 值 。 


单 选 一 项 : 

O 〇 蓝天 @ 白 云 O 大 海 
在 下 拉 莱 单 中 一 项 : 
再 可 司 


| 


11-6 ”使 用 下 拉 列 表 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 9- 


案例 分 析 : 

(1) 下 拉 列 表 是 通过 <select></select> 标 识 表 示 的 。 而 下 拉 列 表 当 中 的 选项 是 通过 包含 在 
其 中 的 <option></option> 标 识 表 示 的 。<select> 标 识 中 name=“ 定 义 下 拉 列 表 的 name 属性 ， 以 
确认 它 的 唯一 性 。<option> 标 识 中 value=“ 定 义 需 要 传递 的 值 。 

(2) 在 formdemohandler.php 文件 中 ， 则 使 用 了 选项 的 name 值 为 “aselect”。 然 后 和 f 语 
句 通过 对 aradio 传递 的 不 同 的 值 做 出 判断 ， 打 印 不 同 的 值 。 


11.3.6” 重 置 按钮 


重 置 按钮 用 来 重 置 所 有 的 表单 输入 的 数据 。 重 置 按钮 的 使 用 ， 仍 然 通过 修改 formdemo 的 
例子 加 以 说 明 ， 具 体 步骤 如 下 。 

在 文件 夹 下 修改 formdemo.html 文件 ， 代 码 如 下 : 

<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 


<h3> 点 击 此 按钮 重 置 所 有 信息 : </h3> 
<input type="RESET" value=" 重 置 " /> 
</form> 
</BODY> 
</HTML> 


运行 formdemo.html， 结 果 如 图 11-7 所 示 。 


六 np/loc.. B P SOX) localhost x [A 
文件 (F) 篇 塌 (E) 查看 (V) 收藏 次 (A) 工具 (T) 帮助 (H) 


输入 一 个 信息 《比如 名 称 ) : 
meziaomine 
确认 此 项 《可 复 选 》: 


选择 此 项 传递 的 A 项 的 value 值 。 回 选择 此 项 传递 的 B 项 的 value 值 。 口 选 
择 此 项 传递 的 C 项 的 value 值 。 


单 选 一 项 : 

OO 蓝天 〇 白云 日 大 海 
在 下 拉 菜 单 中 一 项 : 
点 击 此 按钮 重 置 所 有 信息 : 


EN 


11-7 ”使 用 重 置 按钮 
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重 
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EDUE) 点 单 击 “ 重 置 ” 按 钮 ， 页 面 中 所 有 输入 数据 被 重 置 为 默认 值 ， 如 图 11-8 所 示 。 
| 


全 Eee TE Er x 国 | es 
文件 有” 入 剖 昌吉 VW) 收工 上 0 和 


输入 一 个 信息 《比如 名 称 〉: 


问 准 副 当 qaMJT 翰 上 | 浪 下 


“确认 此 项 《可 复 选 》: 


| 回 选择 此 项 传递 的 A 页 的 value 值 。 口 选择 此 项 传递 的 B 项 的 value 值 。 口 选 
| 择 此 项 传递 的 C 项 的 value 值 。 


单 选 一 项 : 

〇 蓝天 @ 白 云 OQ 大 海 
在 下 拉 菜 单 中 一 项 
Es 
点 测 此 按钮 重 置 所 有 信息 : 


| 呈 a 


图 11-8 单 击 “ 重 置 ” 按 钮 的 结果 


案例 分 析 : 

由 <input type=“RESET”value=“ 重 置 ”> 语句 可 见 ， 重 置 按钮 是 <input /> 标识 的 一 种 。 定 义 
一 个 input 标识 为 单 选项 的 必要 因素 为 : 

<input type="reset" ... /> 


Value 属性 是 按钮 所 显示 的 字符 。 


11.3.7 ”提交 按钮 


到 现在 为 止 ， 上 面 程 序 中 form 里 的 所 有 元 素 都 已 经 设置 完成 ， 并 且 在 相应 的 PHP 文件 
中 做 出 了 处 理 。 这 个 时 候 ， 想 要 把 HTML 页 面 中 所 有 的 数据 发 送出 去 给 相应 PHP 文件 进行 处 
理 ， 就 需要 使 用 submit 按钮 ， 也 就 是 提交 按钮 。 完 成 添加 提交 按钮 ， 并 且 提 交 数 据 。 具 体 步 
又 如 下 。 

在 phpform 文件 夹 下 修改 formdemo.html 文件 ， 最 终 代 码 如 下 : 


<HTML> 
<HEAD></HEAD> 
<BODY> 
<form action="formdemohandler.php" method="post"> 
<h3> 输 入 一 个 信息 (比如 名 称 ) : </h3> 
<input type="text" name="name" size="10" /> 
<h3> 确 认 此 项 (可 复 选 ) : </h3> 
<input type="checkbox" name="achecked" checked="checked" value="1"” /> 
选择 此 项 传递 的 A 项 的 value 值 。 


<input type="checkbox" name="bchecked" value="2" /> 


py HG 
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案例 课堂 >"… 


选择 此 项 传递 的 0 项 的 value 值 。 
<input type="checkbox" name="cchecked" value="3" /> 
选择 此 项 传递 的 c 项 的 value 值 。 
<h3> 单 选 一 项 : </h3> 
<input type="radio" name="aradio" Value="al" /> 蓝天 
<input type="radio" name="aradio" value="a2" checked="checked" /> 和 白云 
<input type="radio" name="aradio" Value="a3" /> 大 海 
<h3> 在 下 拉 菜 单 中 一 项 : </h3> 
<select name="aselect" Size="1"> 
<option value="hainan"> 海 南 </option> 
<option value="qingdao" selected> 青 岛 </option> 
<option value="beijing"> 北 京 </option> 
<option value="xizang"> 西 藏 </option> 
</select> 
<h3> 点 击 此 按钮 重 置 所 有 信息 : </h3> 
<input type="RESET"” value=" 重 置 " /> 
<h3> 点 击 此 按钮 提交 所 有 信息 到 formdemohandler .php 文件 : </h3> 
<input type="submit" value=" 提 交 " /> 
</form> 
</BODY> 
</HTML> 


在 phpform 文件 夹 下 修改 formdemohandler.php 文件 ， 其 最 终 代 码 如 下 : 


<HTML> 
<HEAD></HEAD> 
<BODY> 
<?php 
$name = $_ POST['name']; 
if(isset($ POsT['achecked'])){ 
$achecked = $ POST['achecked']; 
} 
if(isset($ POST['bchecked']))1{ 
$bchecked = $ POST['bchecked']; 
3 
if(isset($ POST['cchecked'])){ 
$cchecked = $ POsT['cchecked']; 
3 
$aradio = $ POsT['aradio']; 
$aselect = $ POsT['aselect']; 
echo $name."<br />"; 
if(isset($achecked) and $achecked == 1)1{ 
echo "选项 A 的 value 值 已 经 被 正确 传递 。<br />"; 
}jelsef 
echo "选项 A 没有 被 选择 ， 其 value 值 没有 被 传递 。<br />"; 


if(isset ($bchecked) and $bchecked == 2){ 
echo "选项 B 的 value 值 已 经 被 正确 传递 。 <br />"; 
}elsef{ 


echo "选项 B 没有 被 选择 ， 其 value 值 没有 被 传递 。<br />"; 


if(isset($cchecked) and $cchecked == 3)1{ 
echo "选项 c 的 value 值 已 经 被 正确 传递 。<br />"; 
}elsef{ 
echo "选项 c 没有 被 选择 ， 其 value 值 没有 被 传递 。<br />"; 
和 
ENSaraGiG EGRA) 
echo "蓝天 <br />"; 
}else if($aradio == 'a2'){ 
echo "白云 cbr />"; 
}elsef{ 
echo "大 海 <br />"; 
if($aselect == 'hainan'){ 
echo "海南 <br />"; 
}else if($aselect == 'qingdao'){ 
echo "青岛 <br />"; 
Jelse if($aselect == 'beijing'){ 
echo "北京 <br />"; 
}else{ 
echo "西藏 "; 
人 
</BODY> 
</HTML> 


运行 formdemo.html， 结 果 如 图 11-9 所 示 。 


CD Sec Bp- sox] Scone。 


EREORETOETTETORE TO 
输入 一 个 信息 《比如 名 称 》: 


[wanexiaonin| 
确认 此 项 (可 复 选 》: 


口 选择 此 项 传递 的 A 项 的 value 值 。 回 选择 此 项 传递 的 B 项 的 value 值 。 
口 选择 此 项 传递 的 C 项 的 value 值 。 


单 选 一 项 : 


NN 


@ 贡 天 白云 大海 
在 下 拉 莱 单 中 一 项 : 
| 
点 击 此 按钮 重 置 所 有 信息 : 

Ei 

点 击 此 按钮 提交 所 有 信息 到 formdemohandler. php 文 件 : 


中 


11-9 使 用 “提交 ”按钮 


EEJYY 单 击 “提交 ”按钮 ， 页 面 将 会 跳 转 到 formdemohandler.php， 输 出 结果 如 图 11-10 
所 示 。 


二 
21@ 
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PHP+MySQL 动 态 网 站 开发 
案例 课堂 »… 


[¢ 回 名 htpylloc.. 国 DP BOX|@ localhost x ee 


文件 (F) ” 坊 强 (E) ”下 看 (V) 收藏 夫 (A) 工 员 (T) 帮助 (H) 


i 及 人 
选项 B 的 value 值 已 经 被 正确 传递 
及 其 value 信 没有 被 传递 


下 100% ~ 


11-10 ” 单 击 “提交 ”按钮 后 的 结果 


11.4 传递 数据 
数据 传递 的 常用 方法 为 POST 和 GET 两 种 ， 下 面 来 介绍 这 两 种 方法 的 使 用 技巧 。 
11.4.1 用 POST 方式 传递 数据 


表单 传递 数据 是 通过 POST 和 GET 两 种 方式 进行 的 。 在 定义 表单 属性 的 时 候 ， 都 要 在 
method 属性 上 定义 使 用 哪 种 数据 传递 方式 。 

<form action=“URI”method=“post”> 定 义 了 此 表单 在 把 数据 传递 给 目标 文件 的 时 候 使 用 的 
是 POST 方式 。<form action=“URI”method=“get”> 则 定义 了 此 表单 在 把 数据 传递 给 目标 文件 
的 时 候 ， 使 用 的 是 GET 方式 。 

POST 方式 是 比较 常见 的 表单 提交 方式 。 通 过 POST 方式 提交 的 变量 ， 不 受 特定 的 变量 大 
小 的 限制 ， 并 且 被 传递 的 变量 不 会 在 浏览 器 地 址 栏 里 以 URL 的 方式 显示 出 来 。 


11.4.2 用 GET 方式 传递 数据 


GET 方式 比较 有 特点 。 通 过 GET 方式 提交 的 变量 ， 有 大 小 限制 ， 不 能 超过 100 个 字符 。 
它 的 变量 名 和 与 之 相对 应 的 变量 值 都 会 以 URL 的 方式 显示 在 浏览 器 地 址 栏 里 。 所 以 ， 若 传递 
大 而 敏感 的 数据 ， 一 般 不 使 用 此 方式 。 

使 用 GET 方式 传递 数据 ， 通 常 是 借助 于 URL 进行 的 。 

下 面 对 此 操作 进行 讲解 ， 具 体 步 骤 如 下 。 

在 网 站 根 目录 下 建立 getparam.php 文件 ， 输 入 以 下 代码 并 保存 : 

<?php 

if(!$ GET['u']) 

echo ' 参 数 还 没有 输入 。'; 


}elsef 
$user = $ GET['u']; 
Switch ($user){ 
case 1: 
echo "用 户 是 王小明 "; 
break; 
case 2: 
echo "用 户 是 李 丽 丽 "; 


break; 


了 
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ED 在 浏览 器 地 址 栏 中 输入 “http://localhost/getparam.php?0”， 并 按 Enter 键 确认 ， 
运行 结果 如 图 11-11 所 示 。 

在 浏览 器 地 址 栏 中 输入 “http://localhost/getparam.php?u=1”， 并 按 Enter 键 确 
认 ， 运 行 结果 如 图 11-12 所 示 。 


【<€ /© EEE EETE ET CG oee. B po- So x] lccahost 


Ee 


图 11-11 程序 运行 结果 一 11-12 ”程序 运行 结果 二 


在 浏览 器 地 址 栏 中 输入 “http://localhost/getparam.php?u=2”， 并 按 Enter 键 确 
认 ， 运 行 结果 如 图 11-13 所 示 。 
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11-13 “程序 运行 结果 三 
案例 分 析 : 


(1) 在 URL 中 ，GET 方式 通过 “?” 号 后 面 的 数组 元 素 的 键 名 (这 里 是 “u”) 来 获得 元 素 
的 值 。 
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(2) 对 元 素 赋值 使 用 “=” 号 。 
(3) switch 条 件 语句 做 出 判断 ， 并 返回 结果 。 


11.5 ”PHP 获取 表单 传递 数据 的 方法 


如 果 表 单 使 用 POST 方式 传递 数据 ， 则 PHP 要 使 用 全 局 变量 数组 $ POST[] 来 读 取 所 传递 
的 数据 。 

表单 中 ， 元 素 传递 数据 给 $ POST[] 全 局 变量 数组 ， 其 数据 以 关联 数组 中 的 数组 元 素 形式 
存在 。 以 表单 元 素 的 名 称 属性 为 键 名 ， 以 表单 元 素 的 输入 数据 或 是 传递 的 数据 为 键 值 。 

比如 上 例 中 ，formdemohandler.php 文件 中 的 Sname=$ POST[ ame"]: 语 句 就 是 读 取 名 为 
name 的 文本 框 中 的 数据 。 此 数据 是 以 name 为 键 名 ， 以 文本 框 输入 的 数据 为 键 值 。 

再 如 ，$achecked=$_ POST['achecked"”] 语 句 读 取 名 为 achecked 的 复 选 框 传递 的 数据 。 此 数 
据 是 以 achecked 为 键 名 ， 以 复 选 框 传递 的 数据 为 键 值 。 

如 果 表 单 使 用 GET 方式 传递 数据 ， 则 PHP 要 使 用 全 局 变量 数组 $ GET[] 来 读 取 所 传递 的 
数据 。 与 $ POST[] 相 同 ， 表 单 中 元 素 传递 数据 给 $_GET[] 全 局 变量 数组 ， 其 数据 以 关联 数组 中 
的 数组 元 素 形式 存在 。 以 表单 元 素 的 名 称 属性 为 键 名 ， 以 表单 元 素 的 输入 数据 或 是 传递 的 数 
据 为 键 值 。 


11.6 ”PHP 对 URL 传递 的 参数 进行 编码 


PHP 对 URL 中 传递 的 参数 进行 编码 ， 一 则 可 以 实现 对 所 传递 数据 的 加 密 ， 二 是 可 以 对 无 
法 通过 浏览 器 进行 传递 的 字符 进行 传递 。 

实现 此 操作 一 般 使 用 urlencode0 函 数 和 rawurlencode() 函 数 。 而 对 此 过 程 的 反 向 操作 就 是 
使 用 urldecode0 函 数 和 rawurldecode() 函 数 。 

下 面 对 此 操作 进行 讲解 ， 具 体 步骤 如 下 。 

在 网 站 根 目 录 下 建立 urlencode.php 文件 ， 输 入 以 下 代码 并 保存 : 


<?php 

$user = ' 王 小 明 刘 晓 莉 ' ; 

$1linkl "index.php?userid=".urlencode ($user)."<br />"; 
$1ink2 "index.php?userid=".rawurlencode ($user) ."<br />"; 
echo $linkl.$1link2; 

echo urldecode ($1ink1); 

echo urldecode ($1ink2); 

echo rawurldecode ($1link2); 

?> 


在 浏览 器 地 址 栏 中 输入 “http://localhost/urlencode.php”， 并 按 Enter 键 确认 ， 运 
行 结果 如 图 11-14 所 示 。 


@ rtpyoc- @ P - cx| localhost x 
文件 (有 ) ” 编 缉 (E) ”查看 (V) 收 巧 夫 (A) ”工具 (T) 帮助 (H) 


index. php3?userid=%CDWF5%WDOWA1%C3%WFT+%C1%FS%WCFWFEWNCO%WF2 
index. php3?userid=%CDWF5%WDO%A1%WC3%WF7%20%C1%FSWCF%WFEXCOWF2 
index. php?userid= 王 小 明 刘 晓 莉 
index. php?userid= 王 小 明 刘 晓 莉 
index. php?userid= 王 小 明 刘 晓 莉 


11-14 ”urlencode.php 文件 的 运行 结果 


案例 分 析 : 

(1) 在 $linkl 变量 的 赋值 中 ， 使 用 urlencode0 函 数 对 一 个 中 文字 符 串 $user 进行 编码 。 

(2) 在 $link2 变量 的 赋值 中 ， 使 用 rawurlencode0O) 函 数 对 一 个 中 文字 符 串 $user 进行 编码 。 

(3) 这 两 种 编码 方式 的 区 别 在 于 对 空格 的 处 理 ，urlencode0 函 数 将 空格 编码 为 “+” 号 ， 
而 rawurlencode0) 函 数 将 空格 编码 为 “%20”。 

(4) urldecodeO) 函 数 实现 对 编码 的 反 向 操作 。 


11.7 ”综合 应 用 PHP 与 Web 表单 


下 面 进 行 处 理 表单 数据 的 讲解 。 此 案例 中 ， 将 假设 一 名 网 络 浏览 者 在 某 酒 店 网 站 上 登记 
房间 。 具 体 步骤 如 下 。 
在 网 站 根 目录 下 建立 一 个 form.html 文件 ， 输 入 以 下 代码 并 保存 : 


<HTML> 
<HEAD> 
<h2>GoodHome online booking form. - GoodHome 在 线 订房 表 。</h2> 
</HEAD> 
<BODY> 
<form action="formhandler.php" method="post"> 
<table> 
<tr bgcolor="#3399FF"> 
<td> 客 人 姓名 :</td> 
<td><input type="text" name="customername" size="10" /></td> 
</tr> 
<tr bgcolor="#CCCCCC"> 
<td> 到 达 时 间 :</td> 
<td><input type="text" name="arrivaltime" size="3" /> 天 内 </td> 
< /tr> 
<tr bgcolor="#3399FF"> 
<td> 联 系 电话 :</td> 
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<td><input type="text" name="phone" size="15" /></td> 
i 
<tr bgcolor="#666666"> 
<td align="center"><input type="submit" value=" 确 认 订房 信息 " /></td> 
</tr> 
</table> 
</form> 
</BODY> 
</HTML> 


ED 在 浏览 器 地 址 栏 中 输入 “http://localhost/form.html”， 并 按 Enter 键 确认 ， 运 行 
结果 如 图 11-15 所 示 。 


名 htp://loc. 入 P -cx| 志 locahos x ee 


文件 (F) ”编辑 (E) 章 看 V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


GoodHome online booking form。- GoodHome 在 线 订房 表 。 


或 100% ~ 


图 11-15 form.html 的 运行 结果 
在 相同 目录 下 建立 一 个 PHP 文件 formhandler.php， 输 入 以 下 代码 并 保存 : 


<HTML> 
<HEAD> 
<h2>GoodHome booking info. - GoodHome 订房 表 确认 信息 。</h2> 
</HEAD> 
<BODY> 
<?php 
$customername = $_ POST['customername']; 
$arrivaltime = $ POST['arrivaltime']; 
$phone = $_ POST['phone']; 
echo '<p> 订 房 确认 信息 :</p>'; 
echo ' 客 人 ' .$customername.' 您 会 在 ' .$arrivaltime 
.， 内 到 达 。 您 的 联系 电话 是 ' .$phone'。'; 
2> 
</BODY> 
</HTML> 


回 到 浏览 器 中 ， 打 开 的 form.html 页 面 。 在 表单 中 输入 数据 。 客 人 姓名 为 “ 王 小 
明 ”、 到 达 时 间 为 “3”、 联 系 电话 为 “1359XXXXX377”， 单 击 “ 确 认 订房 信息 ” 
按钮 ， 浏 览 器 会 自动 跳 转 到 formhandlerphp 页 面 ， 显 示 结果 如 图 11-16 所 示 。 


入 hapyloc- 入 P- SOX)| localhost x a 
文件 六 综 (E) ”过 春 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


GoodHome booking info. 一 GoodHome 订 房 表 确认 信息 。 
订房 确认 信息 : 
客人 王小明 ， 您 将 会 在 3 天 内 到 达 。 您 的 联系 电话 是 1359)0000377。 


图 11-16 formhandler.php 页 面 程序 的 运行 结果 


案例 分 析 : 

(1) 在 form.html 中 的 form 通过 POST 方法 (method) 把 三 个 <input type=“text”... /> 中 的 文 
本 数据 发 送 给 formhandler.php。 

(2) formhandlerphp 中 ， 代 码 读 取 数组 $ POST 中 的 具体 变量 $_POST[‘customername’]、 
$_POST['arrivaltime’]、$_POST[‘phone’]， 并 赋值 给 本 地 变量 $customername、 Sarrivaltime、 
$phone。 然 后 ， 通 过 echo 命令 使 用 本 地 变量 ， 把 信息 生成 HTML 后 输出 给 浏览 器 。 

(3) 要 提 到 的 是 echo“ 客 人“.$customername…， 您 将 会 在 “'.$arrivaltime… 天 内 到 达 。 您 
的 联系 电话 是 “'.$phone…。 :中 的 “.” 是 字符 串 连接 操作 符 。 它 把 不 同 部 分 的 字符 串 连接 在 一 
起 。 在 使 用 echo 命令 的 时 候 经 常会 用 到 它 。 


11.8 疑难 解 惑 


疑问 1: 使 用 urlencode0 和 rawurlencodeO 函 数 需要 注意 什么 ? 


要 注意 的 是 ， 如 果 配 合 js 处 理 页 面 的 信息 的 话 ， 要 注意 使 用 urlencode0 函 数 后 “+” 号 与 
js 的 冲突 。 由 于 js 中 “+” 号 是 字符 串 类 型 的 连接 操作 符 js 才 处 理 ， 否 则 url 就 无 法 识别 其 中 
的 “+” 号 。 这 时 ， 可 以 使 用 rawurlencode0 函 数 对 其 进行 处 理 。 


疑问 2: GET 和 了 POST 的 区 别 和 联系 是 什么 ? 


二 者 的 区 别 与 联系 如 下 。 

(1) POST 是 向 服务 器 传送 数据 ，GET 是 从 服务 器 上 获取 数据 。 

(2) POST 是 通过 HTTP POST 机 制 将 表单 内 各 个 字段 及 其 内 容 放 置 在 HTML HEADER 
内 一 起 传送 到 ACTION 属性 所 指 的 URL 地 址 。 用 户 看 不 到 这 个 过 程 ，GET 是 把 参数 数据 队 
列 加 到 提交 表单 的 ACTION 属性 所 指 的 URL 中 ， 值 和 表单 内 各 个 字段 一 一 对 应 ， 在 URL 中 
可 以 看 到 。 

(3) 对 于 GET 方式 ， 服 务 器 端 用 Request.QueryString 获取 变量 的 值 ， 对 于 POST 方式 ， 
服务 器 端 用 Request.Form 获取 提交 的 数据 。 
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(4) POST 传送 的 数据 量 较 大 ， 一 般 默认 为 不 受 限 制 。 但 理论 上 ，IIS 4 中 最 大 量 为 
80KB，IIS 5 中 为 100KB; GET 传送 的 数据 量 较 小 ， 不 能 大 于 2KB。 

(5) POST 安全 性 较 高 ，GET 安全 性 非常 低 ， 但 是 执行 效率 却 比 POST 方法 好 。 

(6) 在 做 数据 添加 、 修 改 或 删除 时 ， 建 议 用 POST 方式 ; 而 在 做 数据 查询 时 ， 建 议 用 
GET 方式 。 

(7) 对 于 机 密 信 息 的 数据 ， 建 议 采用 POST 数据 提交 方式 。 
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PHP 不 仅 可 以 输出 纯 HIML， 还 可 以 创建 及 操作 多 种 不 同 图 像 格 式 的 图 像 文 
件 ， 包 括 GIF、PNG、JPG、WBMP 和 XPM 等 。 更 方便 的 是 ，PHP 可 以 直接 将 图 
像 流 输出 到 浏览 器 。 要 处 理 图 像 ， 需 要 在 编译 PHP 时 加 上 图 像 函数 的 GD 库 ， 男 
外 ， 还 可 以 使 用 第 三 方 的 图 形 库 。 本 章 我 们 来 讲述 图 形 图 像 的 处 理 方法 和 技巧 。 
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12.1 在 PHP 中 加 载 GD 库 
PHP 中 的 图 形 图 像 处 理 功能 都 要 求 有 一 个 库 文件 的 支持 ， 这 就 是 GD2 库 。PHP 5 中 自 带 


如 果 是 在 Windows 7 系统 环境 下 ， 则 修改 php.ini 中 extension=php_gd2.dll 前 面 的 “;” 即 
可 启用 ， 如 图 12-1 所 示 。 


了 phpjni - 记事 二 
文 伯 ( 虽 ， 妨 得 (E) 格式 (O) 查看 (V) 帮助 (H) 


;extension=php_bz2. dll 
;extension=php_curl. dll 
‘extension=php_dba. dll 
extension=php_mbstring. dll 
f.dll 


;extension=php_gmp. dl 
;extension=php_int1. dll 
;extension=php_imap. dll 
;extension=php_interbase. dll 
;extension=php_ldap. dll 
;extension=php_ming. dll 
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图 12-1 修改 php.ini 配置 文件 


下 面 了 解 一 下 PHP 中 常用 的 图 像 函 数 的 功能 。 具 体 如 表 12-1 所 示 。 


表 12-1 图 像 函 数 的 功能 


函数 
gd_info 


getimagesize 


image type_to_mime type 


功 能 
取得 当前 安装 的 GD 库 的 信息 
取得 图 像 大 小 
取得 getimagesize、exif read_data、exif thumbnail、exif imagetype 所 返回 
的 图 像 类 型 的 MIME 类 型 


image2wbmp 以 WBMP 格式 将 图 像 输出 到 浏览 器 或 文件 
imagealphablending 设 定 图 像 的 混 色 模式 

imageantialias 是 否 使 用 antialias 功能 

imagearc 画 椭圆 弧 

imagechar 水 平地 画 一 个 字符 

imagecharup 垂直 地 画 一 个 字符 

imagecolorallocate 为 一 幅 图 像 分 配 颜 色 


imagecolorallocatealpha 


为 一 幅 图 像 分 配 颜 色 和 透明 度 


imagecolorat 
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取得 某 像素 的 颜色 索引 值 


函 数 


续 表 
功 能 


imagecolorclosest 


取得 与 指定 的 颜色 最 接近 的 颜色 的 索引 值 


imagecolorclosestalpha 


取得 与 指定 的 颜色 加 透明 度 最 接近 的 颜色 的 索引 值 


imagecolorclosesthwb 取得 与 给 定 颜色 最 接近 的 色 度 的 黑白 色 的 索引 
imagecolordeallocate 取消 图 像 颜 色 的 分 配 

imagecolorexact 取得 指定 颜色 的 索引 值 

imagecolorexactalpha 取得 指定 的 颜色 加 透明 度 的 索引 值 

imagecolormatch 使 一 个 图 像 中 调 色 板 版 本 的 颜色 与 真 彩色 版 本 更 能 匹配 
imagecolorresolve 取得 指定 颜色 的 索引 值 或 有 可 能 得 到 的 最 接近 的 蔡 代 值 
imagecolorresolvealpha 取得 指定 颜色 加 透明 度 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorset 给 指定 调 色 板 索 引 设 定 颜色 

imagecolorsforindex 取得 某 索 引 的 颜色 

imagecolorstotal 取得 一 幅 图 像 的 调 色 板 中 颜色 的 数目 
imagecolortransparent 将 某 个 颜色 定义 为 透明 色 

imagecopy 拷贝 图 像 的 一 部 分 

imagecopymerge 拷贝 并 合并 图 像 的 一 部 分 

imagecopymergegray 用 灰 度 拷贝 并 合并 图 像 的 一 部 分 

imagecopyresampled 重 采样 拷贝 部 分 图 像 并 调整 大 小 

imagecopyresized 拷贝 部 分 图 像 并 调整 大 小 

imagecreate 新 建 一 个 基于 调 色 板 的 图 像 

imagecreatefromgd2 从 GD2 文件 或 URL 新 建 一 图 像 
imagecreatefromgd2part 从 给 定 的 GD2 文件 或 URL 中 的 部 分 新 建 一 图 像 
imagecreatefromgd 从 GD 文件 或 UR 新 建 一 图 像 

imagecreatefromegif 从 GIF 文件 或 URL 新 建 一 图 像 

imagecreatefromjpeg 从 JPEG 文件 或 URL 新 建 一 图 像 

imagecreatefrompng 从 PNG 文件 或 URL 新 建 一 图 像 

imagecreatefromstring 从 字符 串 中 的 图 像 流 新 建 一 图 像 

imagecreatefromwbmp 从 WBMP 文件 或 URL 新 建 一 图 像 

imagecreatefromxbm 从 XBM 文件 或 URL 新 建 一 图 像 

imagecreatefromxpm 从 XPM 文件 或 URL 新 建 一 图 像 

imagecreatetruecolor 新 建 一 个 真 彩 色 图 像 

imagedashedline 画 一 虚线 
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续 表 
函 数 功 能 
imagedestroy 销毁 一 图 像 
imageellipse 画 一 个 椭圆 
imagefill 区 域 填充 
imagefilledarc 画 一 椭圆 弧 且 填充 
imagefilledellipse 画 一 椭圆 并 填充 
imagefilledpolygon 画 一 多 边 形 并 填充 
imagefilledrectangle 画 一 矩形 并 填充 
imagefilltoborder 区 域 填充 到 指定 颜色 的 边界 为 止 
imagefontheight 取得 字体 高 度 
imagefontwidth 取得 字体 宽度 
imageftbbox 取得 使 用 了 FreeType 2 字体 的 文本 的 范围 
imagefttext 使 用 FreeType 2 字体 将 文本 写 入 图 像 
imagegd 将 GD 图 像 输出 到 浏览 器 或 文件 
imagegif 以 GIF 格式 将 图 像 输 出 到 浏览 器 或 文件 
imagejpeg 以 JPEG 格式 将 图 像 输出 到 浏览 器 或 文件 
imageline 画 一 条 直线 
imagepng 将 调 色 板 从 一 幅 图 像 拷 贝 到 另 一 幅 
imagepolygon 画 一 个 多 边 形 
imagerectangle 画 一 个 矩形 
imagerotate 用 给 定 角度 旋转 图 像 
imagesetstyle 设 定 画 线 的 风格 
imagesetthickness 设 定 画 线 的 宽度 
imagesx 取得 图 像 宽度 
imagesy 取得 图 像 高 度 
imagetruecolortopalette 将 真 彩色 图 像 转换 为 调 色 板 图 像 
imagettfbbox 取得 使 用 TrueType 字体 的 文本 的 范围 
imagettftext 用 TrueType 字体 向 图 像 写 入 文本 


12.2 图形 图 像 的 典型 应 用 案例 


下 面 讲 述 图 形 图 像 的 经 典 使 用 案例 。 


六 


第 
12.2.1 创建 一 个 简单 的 图 像 sl 
处 
使 用 GD2 库 文件 ， 就 像 使 用 其 他 库 文件 一 样 。 由 于 它 是 PHP 的 内 置 库 文件 ， 不 需要 在 
PHP 文件 中 再 用 inelude 等 函数 进行 调用 。 以 下 实例 介绍 图 像 的 创建 方法 。 
【 例 12.1】( 示 例文 件 ch12\12.1.php) 
<?php 
$im = imagecreate (200,300); // 创 建 一 个 画布 
$white = imagecolorallocate ($im，8,2,133); ”// 设 置 画 布 的 背景 色 为 一 种 蓝 色 
imagegif ($im); // 输 出 图 像 


运行 程序 ， 结 果 如 图 12-2 所 示 。 本 例 使 用 imagecreate0 函 数 创建 了 一 个 宽 200 像素 、 高 
300 像素 的 画布 ， 并 设置 画布 的 RGB 值 为 (8, 2, 133)， 最 后 输出 一 个 GIF 格式 的 图 像 。 


本 
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文件 (月 ” 狂 强 (E) ”查看 (V) 收藏 交 (A) 工具 (T) 帮助 (H) 


IGG 
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12-2 ”图 像 的 创建 


pr 使 用 imagecreate(200, 300) 函 数 创建 基于 普通 调 色 板 的 画布 ， 支 持 256 色 ， 其 中 


了 损坏 
SS。 ”200, 300 为 图 像 的 宽度 和 高 度 ， 单 位 为 像素 。 
上 面 的 案例 只 是 把 图 片 输出 到 页 面 ， 那 么 如 果 需 要 保存 图 片 文 件 呢 ? 下 面 通 过 例子 来 介 
绍 图 像 文 件 的 创建 方法 。 
【 例 12.2】( 示 例文 件 ch12\12.2.php) 
<?php 
$ysize = 200; 


$xsize = 3007 
$theimage = imagecreatetruecolor ($xsize, $ysize); 


$color2 = imagecolorallocate ($theimage, 8,2,133); 
$color3 = imagecolorallocate ($theimage, 230,22,22); 
imagefill($theimage, 0, 0, $color2); 
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imagearc ($theimage,100,100,150,200,0,270, $color3); 
imagejpeg ($theimage, "newimage.jpeg"); 

header ('content-type: image/png'); 

imagepng ($theimage); 

imagedestroy ($theimage); 

二 


运行 程序 ， 结 果 如 图 12-3 所 示 。 同 时 在 程序 文件 夹 下 生成 了 一 个 名 为 newimage.jpeg 的 
图 片 ， 其 内 容 与 页 面 显示 的 相同 。 


ee 
loc- 起 了- Cx 3 localhost 


文件 (P。 编 句 (5) ”查看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 


戈 150% ~ 


图 12-3 页面 效果 


案例 分 析 : 

(1) imagecreatetruecolor() 函 数 是 用 来 创建 图 片 画 布 的 。 它 需要 两 个 参数 ， 一 个 是 x 轴 的 
大 小 ， 一 个 是 y 轴 的 大 小 。$xsize=200; $ysize=300: 分 别 设 定 了 这 两 参数 的 大 小 。$theimage= 
imagecreatetruecolor($xsize, $ysize): 使 用 这 两 个 参数 生成 了 画布 ， 并 且 赋 值 为 Stheimage。 

(2) imagearc($theimage, 100,100.150.200.0.270， $color3): 语 句 使 用 imagearc() 函 数 在 画布 上 
创建 了 一 个 弧 线 。 它 的 参数 分 为 以 下 几 个 部 分 : Stheimage 为 目标 画布 ，“100,100” 为 弧 线 中 
心 点 的 x、y 坐标 ，“150.200” 为 弧 线 的 宽度 和 高 度 ，“0.270” 为 顺 时 针 画 弧 线 的 起 始 度数 
和 终点 度数 ， 是 在 0 到 360 度 之 间 ，$color3 为 画 弧 线 所 使 用 的 颜色 。 
(3) imagejpegO 函 数 是 生成 JPEG 格式 的 图 片 的 函数 。 这 里 ，imagejpeg($theimage， 
“newimage.jpeg”); 把 画布 对 象 $theimage 及 其 所 有 操作 生成 为 一 个 名 为 newimage.jpeg 的 JPEG 
图 片 文件 ， 并 且 直 接 储存 在 当前 路 径 下 。 

(4) 同时 ，header(‘content-type: image/png”); 和 imagepng($theimage): 向 页 面 输出 了 一 张 
PNG 格式 的 图 片 。 

(5) 最 后 清除 对 象 ， 释 放 资 源 。 


12.2.2 ”使 用 GD2 的 函数 在 照片 上 添加 文字 


上 面 是 如 何 创建 一 个 图 片 。 如 果 想 在 图 片上 添加 文字 ， 就 需要 修改 一 个 图 片 ， 具 体 的 过 
程 为 : 先 读 取 一 个 图 片 ， 然 后 修改 这 个 图 片 。 

【 例 12.3】( 示 例文 件 ch12\12.3.php) 

<?php 


$theimage = imagecreatefromijpeg('newimage.jpeg'); 
$colorl = imagecolorallocate($theimage, 255,255,255); 


$color3 = imagecolorallocate ($theimage, 230,22,22); 
imagestring($theimage,5,60,100,'Text added to this image.',$colorl); 
header ('content-type: image/png'); 

imagepng ($theimage); 

imagepng ($theimage, 'textimage.png'); 

imagedestroy ($theimage); 

?> 


运行 程序 ， 结 果 如 图 12-4 所 示 。 同 时 在 程序 所 在 的 文件 夹 下 生成 了 名 为 newimagejpeg 
的 图 片 文件 ， 其 内 容 与 页 面 显示 相同 。 


¢3 》 loc- B PD- BCX localhost 
文件 (。 骗 总 (E) ”查看 (V) 收藏 夫 (A) ”工具 (T) 帮助 (H) 
Text added to this image. 
R150% ~ 


图 12-4 在 照片 上 添加 文字 


案例 分 析 : 

(1) imagecreatefromjpeg(mewimage.jpeg7): 语 句 中 imagecreatefromjpegO 函 数 从 当前 路 径 下 
读 取 newimage.jpeg 图 形 文件 ， 并 且 传 递 给 Stheimage 变量 作为 对 象 ， 以 待 操作 。 

(2) 选取 颜色 后 。imagestring($theimage,5.60.100,“‘Text added to this image.”,$color1): 语 句 
中 的 imagestringO 函 数 向 对 象 图 片 添加 字符 串 'Text added to this image."。 这 里 面 的 参数 中 ， 
Stheimage 为 对 象 图 片 ， “5” 为 字体 类 型 ， 这 个 字体 类 型 的 参数 从 1 到 5 代表 不 同 的 字体 ; 
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“60,100” 为 字符 串 添加 的 起 始 x、y 坐标 ; “Text added to this image. 为 要 添加 的 字符 串 ， 当 前 
只 支持 ASC 字符 ; Scolorl 为 文字 的 颜色 。 

(3) header(‘content-type: image/png’); 和 imagepng($theimage): 语 句 共同 处 理 了 输出 到 页 面 
的 PNG 图 片 。 之 后 ， imagepng($theimage,“textimage.png”): 语 句 就 创建 文件 名 为 textimage.png 
的 PNG 图 片 ， 并 保存 在 当前 路 径 下 。 


12.2.3 ”使 用 TrueType 字体 处 理 中 文生 成 图 片 


字体 处 理 在 很 大 程度 上 是 PHP 图 形 处 理 经 常 要 面 对 的 问题 。imagestringO 函 数 默认 的 字体 
是 十 分 有 限 的 。 这 就 要 进入 字体 库 文件 。 而 TrueType 字体 是 字体 中 极为 常用 的 格式 。 例 如 ， 
在 Windows 下 打开 C:\\WINDOWS\Fonts 目录 ， 会 出 现 很 多 字体 文件 ， 其 中 绝 大 部 分 是 
TrueType 字体 ， 如 图 12-5 所 示 。 


GO" rn, OO Ee 5 
ENP mae) Rn 
ee 更 汪 、 弄 险 或 者 品 示 和 隐 和 夏 机 上 安 尝 5 李 体 
= ap mE 下 
my - 
ee aasepl inte White wgtig am wrgsrg sm Wtngt WR are Rn 
简体 字 ”简体字 简体 字 简体字 人 简体字， 简体 宫 ”简体字 
TAR。 pp Rs 
简体 字画 体 守 ， 简体字 简体 字 简体字 ”简体字 ， 简体字 
NAR RM 
前 体 字 简体 宁 简体字 简体 宁 简体 字 
pd 2m Eas 
ee EEC TO 


图 12-5 ”系统 中 的 字体 


PHP 使 用 GD2 库 ， 在 Windows 环境 下 ， 需 要 给 出 TrueType 字体 所 在 的 文件 夹 路 径 ， 如 
在 文件 开头 使 用 以 下 语句 : 


putenv ('GDFONTPATH=C: \WINDOWS\Fonts'); 


使 用 TrueType 字体 也 可 以 直接 使 用 imagettftext0 函 数 。 它 是 使 用 ttf 字体 的 imagestring() 
函数 。 其 格式 为 : 

imagettftext (图 片 对 象 ， 字 体 大 小 ， 文 字 显示 角度 ， 起 始 x 坐标 ， 起 始 y 坐标 ， 文 字 颜色 ， 字 体 

名 称 ， 文 字 信息 ) 

另外 ， 一 个 很 重要 的 问题 就 是 GD 库 中 的 imagettftextO 函 数 默认 是 无 法 支持 中 文字 符 并 添 
加 到 图 片上 去 的 。 这 是 因为 GD 库 的 imagettftext0 函 数 对 于 字符 的 编码 是 采用 的 UTF-8 的 编 
码 格式 ， 而 简体 中 文 的 默认 格式 为 GB2312。 

以 下 就 介绍 这 样 的 一 个 例子 。 具 体操 作 步 又 如 下 。 

把 C:\\WWINDOWS\Fonts 下 的 字体 文件 simhei.ttf 复制 到 与 文件 12.4.php 相同 的 目 


这 


第 
录 下 。 总 
S57 在 网 站 目录 下 建立 12.4.php 文件 ， 输 入 以 下 代码 并 保存 : | 
<?php 外 
$ysize = 200; 
$xsize = 300; 形 
$theimage = imagecreatetruecolor ($xsize, S$ysize); 
$color2 = imagecolorallocate($theimage, 8,2,133); 
$color3 = imagecolorallocate($theimage, 230,22,22); 


imagefill($theimage, 0, 0, $color2); 

$fontname = 'simhei.ttf'; 

$zhtext = "这 是 一 个 把 中 文 用 黑体 显示 的 图 片 。"; 

$text = iconv("GB2312", "UTF-8", $zhtext); 

imagettftext ($theimage, 12,0,20,100, $color3, $fontname, $text); 
header ('content-type: image/png'); 

imagepng ($theimage); 

imagedestroy ($theimage); 

?> 


运行 程序 ， 结 果 如 图 12-6 所 示 。 


[(€) @ httpy/loc.. @ P BC XE localhost 


文件 (F) ” 编 铝 (E) 音 看 (V) ”收藏 突 (A) 工具 (T) 帮助 (H) 


IGG 


12-6 ”把 中 文 用 黑体 显示 的 图 片 


案例 分 析 : 
(1) imagefill($theimage, 0, 0,$color2); 之 前 的 语句 是 创建 画布 、 填 充 颜 色 的 。 
(2) Sfontmame=“simhei.ttf ;语句 确认 了 当前 目录 下 的 黑体 字 的 ttf 文件 ， 并 且 把 路 径 赋值 


给 $fontname 变量 。 


(3) $zhtext 中 ， 中 文字 符 的 编码 为 GB2312。 为 了 转换 此 编码 为 UTF-8， 使 用 $text= 


iconv(“GB2312”，“UTF-8”，$zhtext): 语 句 把 $zhtext 中 的 中 文 编码 转换 为 UTF-8， 并 赋值 给 $text 
变量 。 


(4) imagettftext($theimage,12,0,20,100,$color3,$Sfontname,$text); 语 句 按照 ima gettftext() 函 


数 的 格式 分 别 确认 了 参数 。S$theimage 为 目标 图 片 ，“12” 为 字符 的 大 小 ，“0” 为 显示 的 角 
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度 ，“20,100” 为 字符 串 显示 的 初始 x、y 的 值 。$fontname 为 已 经 设 定 的 黑体 ，Stext 为 已 经 
转换 为 UTF-8 格式 的 中 文字 符 串 。 


12.3 Jpgraph 库 的 基本 操作 


Jpgraph 是 一 个 功能 强大 且 十 分 流行 的 PHP 外 部 图 片 处 理 库 文件 。 它 是 建立 在 内 部 库 文件 
GD2 库 之 上 的 。 它 的 优点 是 建立 了 很 多 方便 操作 的 对 象 和 函数 ， 能 够 大 大 地 简化 使 用 GD 库 
对 图 片 进 行 处 理 的 编程 过 程 。 


12.3.1 Jpgraph 的 安装 


Jpgraph 的 安装 就 是 PHP 对 Jpgraph 类 库 的 调用 。 可 以 采用 多 种 形式 。 但 是 ， 首 先 都 需要 
到 Jpgraph 的 官方 网 站 下 载 类 库 文 件 的 压缩 包 。 到 http://jpgraph.net/download/ 下 载 最 新 的 压缩 
包 ， 即 Jpgraph3.5.0bl1。 解 压 以 后 ， 如 果 是 Linux 系统 ， 可 以 把 它 放 置 在 lib 目录 下 ， 并 且 使 
用 下 面 的 语句 重 命名 此 类 库 的 文件 夹 : 

ln -s jpgraph-3.x jpgraph 

如 果 是 Windows 系统 ， 在 本 机 WAMP 的 环境 下 ， 则 可 以 把 类 库 文件 夹 放 在 www 目录 
下 ， 或 者 放置 在 项 目的 文件 夹 下 。 

然后 在 程序 中 引用 的 时 候 ， 直 接 使 用 require_once0 命 令 ， 并 且 指 出 Jpgraph 类 库 相 对 于 
此 应 用 的 路 径 。 

在 本 机 环境 下 ， 把 jpgraph 文件 夹 放置 在 D:\php5.5\ch12 文件 夹 下 。 在 应 用 程序 的 文件 中 
加 载 此 库 ， 使 用 require_once (‘jpgraph/src/jpgraph.php”); 即 可 。 


12.3.2 ”Jpgraph 的 配置 


使 用 Jpgraph 类 前 ， 需 要 对 PHP 系统 的 一 些 限制 性 参数 进行 修改 。 具 体 修改 以 下 3 个 方 
面 的 内 容 。 

(1) 需要 到 php.ini 中 修改 内 存 限 制 ，memory_limit 至 少 为 32m， 本 机 环境 为 momery_ 
limit = 64m。 

(2) 最 大 执行 时 间 max_execution time 要 增加 ，Jpgraph 类 的 官方 推荐 时 间 为 30 秒 ， 即 
max execution time = 30。 


(3) 用 “;” 号 注释 掉 output_buffering 选项 。 


12.4 制作 柱 形 图 和 折线 图 /统计 图 


Jpgraph 库 安装 设置 生效 以 后 ， 就 可 以 使 用 此 类 库 了 。 由 于 Jpgraph 有 很 多 示例 ， 所 以 读 
者 可 以 轻松 地 通过 示例 来 学 习 。 


加 


下 面 通过 一 个 例子 来 学 习 Jpgraph 类 的 使 用 方法 和 技巧 。 

ED 找到 安装 过 的 jpgraph 类 库 文件 夹 ， 在 其 下 的 src 文件 夹 下 找到 Examples 文件 
夹 。 找 到 barlinealphaexl.php 文件 ， 将 其 复制 到 ch12 文件 夹 下 。 在 浏览 器 中 打开 ， 
代码 如 下 : 


<?php 

//content="text/plain; charset=utf-8"; 

require once('jpgraph/src/jpgraph.php'); 
require once('jpgraph/src/ijpgraph bar.php'); 
require once('jpgraph/src/jpgraph line.php'); 
$ydata = array(10,120,80,190,260,170,60,40,20,230); 
$ydata2 = array(10,70,40,120,200,60,80,40,20,5); 
$months = $gDateLocale->GetShortMonth(); 

$graph = new Graph(300,200); 

$graph->SetScale ("textlin"); 
$graph->SetMarginColor ('white'); 
$graph->SetMargin(30,1,20,5); 

S$graph->SetBox(); 

$graph->SetFrame (false); 
$graph->tabtitle->set ('Year 2003'); 
$graph->tabtitle->SetFont (FF_ARIAL,FS BOLD,10); 
$graph->ygrid->SetFill (true, '#DDDDDD@O0 .5', '#BBBBBB@O0 .5'); 
$graph->ygrid->SetLinestyle('dashed'); 
$graph->ygrid->SetColor('gray'); 
$graph->xgrid->Show(); 
$graph->xgrid->SetLinestyle('dashed'); 
$graph->xgrid->SetColor('gray'); 
$graph->xaxis->SetTickLabels ($months); 
$graph->xaxis->SetFont (FF_ARIAL,FS_ NORMAL, 8); 
$graph->xaxis->SetLabelAngle (45); 

$bplot = new BarPlot ($ydata); 
$bplot->SetWwidth (0.6); 

$fcol = "#440000'; 

$tcol = '#FF9090'; 
$bplot->SetFillGradient ($fcol, $tcol,GRAD LEFT REFLECTION); 
Sbplot->SetWeight(0) 7 

$graph->Add ($bplot); 

$1lplot = new LinePlot ($ydata2); 
$1lplot->SetFillColor('skyblue@0.5°'); 
$1lplot->SetColor('navy@0.7'); 
$lplot->SetBarCenter (); 
$1lplot->mark->SetType (MARK SQUARE); 
$lplot->mark->SetColor ('blue@0.5°'); 
$1lplot->mark->SetFillColor('lightblue'); 
$lplot->mark->SetSize(6); 

$graph->Add ($1plot); 

$graph->Sstroke (); 
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修改 require_once(‘jpgraph/ipgraphphp’): 为 require_once(‘jpgraph/src/jpgraph.php’);。 
修改 require_ once(jpgraph/ipgraph barphp7): 为 require_once(ipgraph/src/ipgraph_barphp”);。 
修改 require_once(jpgraph/jpgraph_line .php"): 为 require_once(‘jpgraph/src/jpgraph_line. 
php”); 以 载 入 本 机 Jpgraph 类 库 。 

运行 barlinealphaex1.php， 结 果 如 图 12-7 所 示 。 


@ rtpyoc. @ P -BCx| localhost 
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Ly 
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案例 分 析 : 

(1) require_once(‘jpgraph/src/jpgraph.php’); require_once(‘jpgraph/src/jpgraph_bar.php’); 和 
require_once(“jpgraph/src/jpgraph_line.php”): 语 句 加 载 了 Jpgraph 基本 类 库 jpgraph.php、 柱 状 图 
类 库 jpgraph_bar.php 和 折线 图 类 库 jpgraph_line.php。 

(2) S$ydata=array(10,120,80,190,260,170,60,40,20,230); 和 S$ydata2=array(10,70,40,120,200,60, 
80,40,20,5); 语 句 定义 了 柱状 图 和 折线 图 在 y 轴 上 的 数据 坐标 ， 也 是 图 形 要 表示 的 主要 信息 。 

(3) $months = $gDateLocale->GetShortMonth(); 定 义 了 月 份 使 用 短 名 表示 。 

(4) $graph = new Graph(300,200): 语 句 创 建 图 形 $graph， 高 300 像素 ， 宽 200 像素 。 

(5) $egraph->SetScale(“textlin”): 语 句 确认 刻度 为 自动 生成 的 刻度 形式 。$graph->SetMargin 
Color(“white’); 语 句 确认 图 形 边框 颜色 为 白色 。 

(6) $egraph->SetMargin(30,1,20,5); 语 句 调 整 边框 宽度 。$graph->SetBox0; 语 句 在 背景 图 上 
添加 边框 。$graph->SetFrame(false): 语 句 取消 整个 图 片 的 边框 。 

(7) Sgraph->tabtitle->Set(“Year 2003”): 语 句 添加 图 片 标题 。$graph->tabtitle->SetFont(FF_ 
ARIAL,FS_BOLD,10); 语 句 设 定 标题 样式 。 

(8) Sgraph->ygrid->SetFill(true,#DDDDDD@0.5”,#BBBBBB@0.5): 语 句 设 定 y 轴 方 向 上 
的 网 格 填充 颜色 和 亮度 。S$graph->ygrid->SetLineStyle(“dashed”); 语 句 设 定 y 轴 方 向 上 的 网 格 线 
的 样式 为 虚线 。$graph->ygrid->SetColor(“gray”): 语 句 设 定 y 轴 方 向 上 的 网 格 线 的 颜色 。 


(‘gray”); 语 句 是 对 x 轴 方 向 网 格 的 同 理 设 定 。 


的 $months 变量 中 的 数据 。$graph->xaxis->SetFont(FF ARIAL，FS_ NORMAL,8); 语 句 设 定 样 
式 。$graph->xaxis->SetLabelAngle(45): 语 句 设 定 角度 。 


SetWidth(0.6): 定 义 宽 度 。S$bplot>SetFillGradient(SfcolStcoLGRAD LEFT REFLECTION); 填 充 柱 
状 图 ， 并 且 使 用 填充 的 渐变 样式 和 两 个 渐变 的 颜色 。$graph->Add($bplob: 语 句 添加 柱状 图 到 
图 形 中 。 

(‘skyblue(@0.5”); 和 $lplot->SetColor(“navy(@0.7”); 语 句 定义 折线 区 域 的 颜色 和 透明 度 。 


SetColor(“blue(@0.5”); 定 义 颜色 和 透明 度 。S$lplot->mark->SetSize(6); 定 义 大 小 。S$graph->Add 
($lplot); 语 句 添 加 折线 图 到 图 形 中 。 
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Sgraph->xgrid->Show(); 、$graph->xgrid->SetLineStyle(‘dashed’); 和 S$graph->xgrid->SetColor 


(9) S$graph->xaxis->SetTickLabels($months): 语 句 为 对 x 轴 的 设 定 ， 它 使 用 的 是 先前 定义 


茧 困 水 困 月 这 几 Z 小 


(10) $bplot = new BarPlot($ydata); 语 句 采用 先前 的 Sydata 数据 生成 柱状 图 。S$bplot-> 


(11) $lplot = new LinePlot($ydata2); 语 句 用 $ydata2 数组 生成 折线 图 。S$lplot->SetFillColor 


(12) $lplot->mark->SetType(MARK_SQUARE); 定 义 折线 图 标记 点 的 类 型 。$lplot->mark-> 


(13) $graph->Stroke(); 语 句 表示 把 此 图 传递 到 浏览 器 显示 。 


12.5 制作 圆 形 统计 图 


下 面 就 通过 圆 形 统计 图 例子 的 介绍 ， 来 了 解 Jpgraph 类 的 使 用 ， 有 具体 步骤 如 下 。 
ED 找到 安装 过 的 jpgraph 类 库 文件 夹 ， 在 其 下 的 src 文件 夹 下 找到 Examples 文件 
夹 。 找 到 balloonex1.php 文件 ， 将 其 复制 到 ch12 文件 夹 下 。 代 码 如 下 : 


<?php 
require once('jpgraph/jpgraph.php'); 
require once('jpgraph/jpgraph scatter.php'); 
$datax array(lr ard A da 
$datay = array (12,23,95,18,65,28,86,44); 
function FCallback ($aVval) { 
//This callback will adjust the fill color and size of 
//the datapoint according to the data value according to 
zfE($SaVal < 30) $c = "blue"; 
elseif($aVal < 70) $c = "green"; 
else $c = "red"; 
return array (floor ($aVal/3),"", $c); 
:! 
$graph = new Graph (400,300,'auto'); 
$graph->setscale ("linlin"); 
$graph->img->SsetMargin (40,100,40,40); 
$graph->setshadow (); 
$graph->title->Set ("Example of ballon scatter plot"); 
$graph->yaxis->scale->SetGrace (50,10); 


py A 


$graph—>xaxis->SetPos('min'); 
$spl = new ScatterPlot ($datay, $datax); 
$spl->mark->SetType (MARK FILLEDCIRCLE); 
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$spl->value->Show (); 
$spl->value->SetFont (FF_FONT]1,FS BOLD); 
$spl->mark->SetCallback ("FCallback"); 
$spl->SetLegend('Year 2002'); 
$graph->Add ($sp1); 

$graph->stroke (); 

2 


修改 require_once(“jpgraph/ipgraphphp”): 为 require_once('jpgraph/src/ipgraph.php”);。 修 
改 require_once(‘jpgraph/ipgraph_scatter.php’); 为 require_once(‘ipgraph/src/ipgraph_scatter.php’);。 
以 载 入 本 机 了 pgraph 类 库 。 

运行 balloonex1.php， 结 果 如 图 12-8 所 示 。 


[< Er EE ER 
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Example of ballon scatter plot 
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图 12-8 balloonex1.php 页 面 的 效果 


案例 分 析 : 

(1) require_once('jpgraph/src/jpgraph.php'); 语 句 和 require_once(“jpgraph/src/jpgraph scatter. 
php”); 语 句 加 载 了 Jpgraph 基本 类 库 jpgraph.php 和 圆 形 图 类 库 jpgraph_bar.php。 

(2) $datax 和 $datay 定义 了 两 组 要 表现 的 数据 。 

(3) function FCallback(SaVal){} 函 数 定义 了 不 同 数值 范围 内 的 图 形 的 颜色 。 

(4) $graph = new Graph(400,300,“auto’): 语 句 生成 图 形 。S$graph->SetScale(“linlin”); 生 成 刻 
度 。$graph->img->SetMargin(40.100.40.40): 设 置 图 形 边 框 。S$graph->SetShadow0: 设 置 阴影 。 
$egraph->title->Set(“Example of ballon scatter plot”):; 设 置 标题 。$graph->xaxis->SetPos(“min’); 设 
置 x 轴 的 位 置 为 初始 值 。 

(5) $spl = new ScatterPlot($datay.$datax): 生 成 数据 表示 图 。$sp1->mark->SetType(MARK 
FILLEDCIRCLE); 设 置 数据 表示 图 的 类 型 。$sp1->value->Show0: 展 示 数 据 表示 图 。$sp1l-> 
Value->SetFont(FF FONT1.FS BOLD): 设 定 展示 图 的 字体 。$sp1->SetLegend("Year 2002”); 设 置 
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标题 。 
(6) Sgraph->Add($sp1); 添 加 数据 展示 图 到 整体 图 形 中 。 
(7) $graph->Stroke0: 语 句 表 示 把 此 图 传递 到 浏览 器 显示 。 


葡 困 展厅 月 育才 Z 滤 


12.6 制作 3D 饼 形 统计 图 


下 面 就 通过 3D 饼 形 图 例 程 的 介绍 ， 来 了 解 pgraph 类 的 使 用 方法 和 技巧 。 
ERD 找到 安装 过 的 jpgraph 类 库 文件 夹 ， 在 其 下 的 sre 文件 夹 下 找到 Examples 文件 
夹 。 找 到 pie3dex3.php 文件 ， 将 其 复制 到 ch12 文件 夹 下 。 打 开 查 看 ， 代 码 如 下 : 


<?php 
require once('jpgraph/ jpgraph.php'); 


require once('jpgraph/jpgraph pie.php'); 

require once('jpgraph/jpgraph pie3d.php'); 

$data = array(20,27,45,75,90); 

$graph = new PieGraph (450,200); 

$graph->SetShadow() 7 

$graph->tit1le->Set ("Example 1 3D Pie plot"); 

$graph->title->SetFont (FF_VERDANA,FS BOLD,18); 

$graph->title->SetColor ("darkblue"); 

$graph->legend->Pos (0.5,0.8); 

$pl = new PiePlot3d($data); 

$pl->SetTheme ("sand"); 

$pl->SetCenter (0.4); 

$pl->setAngle (30); 

$pl->value->SetFont (FF_ARIAL,FS_ NORMAL,12); 

$pl->SetLegends (array ("Jan", "Feb","Mar", "Apr", "May", "Jun", "Jul", 
"Aug", "Sep", "Oct")); 

$graph->Add ($p1); 

$graph->stroke (); 

> 
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修改 require_once('jpgraph/ipgraphphp”): 为 require_once('jpgraph/src/ipgraph .php ):。 修 
改 require_once(‘jpgraph/jpgraph_pie.php”): 为 require once('jpgraph/srcjipgraph piephp):。 修 
改 require once(jpgraph/ipgraph pie3dphp”); 为 require_once(‘jpgraph/src/jpgraph_pie3d. 
php"):。 目 的 是 载 入 本 机 Jpgraph 类 库 。 

运行 pie3dex3.php， 结 果 如 图 12-9 所 示 。 

案例 分 析 : 

(1) require_ once(*jpgraph/src/ipgraph.php7): 语 句 require_once(‘jpgraph/ipgraph piephp”); 和 
require_once(‘jpgraph/jpgraph_pie3d.php’); 语 句 加 载 了 Jpgraph 基本 类 库 jpgraph.php、 饼 形 图 类 
库 jpgraph_pie php 和 3d 饼 形 图 类 库 ipgraph_pie3dphp。 

(2) $data 定义 了 要 表现 的 数据 。 

(3) $graph = new PieGraph(450,200): 生 成 图 形 。S$graph->SetShadow(); 设 定 阴影 。 
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[¢ 固 @ http://loc.. @ PD- BoX|| localhost 


文件 (F) ”编辑 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


Example 1 3D Pie plot 
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12-9 ”pie3dex3.php 页 面 的 效果 


(4) $graph->title->Set(“Example 1 3D Pie plot): 设 定 标题 。$graph->title->SetFont(FF 
VERDANA,FS_BOLD,18): 设 定 字体 和 字体 大 小 。$graph->title->SetColor(“darkblue”); 设 定 颜 
色 。$graph->legend->Pos(0.5,0.8): 设 定 图 例 在 整个 图 形 中 的 位 置 。 

(5) S$pl = new PiePlot3d($data); 生 成 饼 形 图 。$p1->SetTheme(“sand”); 设 置 饼 形 图 模板 。 
$p1->SetCenter(0.4); 设 置 饼 形 图 的 中 心 。$pl1->SetAngle(30):; 设 置 饼 形 图 角度 。S$p1->value-> 
SetFont(FF_ARIAL,FS_NORMAL,12); 设 置 字体 。$p1->SetLegends(array(“Jan”…,“Oct”)); 设 置 图 
例文 字 信息 。 

(6) $graph->Add($p1): 向 整个 图 形 添 加 饼 形 图 。$graph->Stroke0: 把 此 图 传递 到 浏览 器 进 
行 显示 。 


12.7 疑难 解 惑 


疑问 1: 不 同 格式 的 图 片 使 用 上 有 何 区 别 ? 


答 : JPEG 格式 是 一 个 标准 。JPEG 经 常用 来 储存 照片 和 拥有 很 多 颜色 的 图 片 ， 它 不 强调 
压缩 ， 强 调 的 是 对 图 片 信息 的 保存 。 如 果 使 用 图 形 编辑 软件 缩小 JPEG 格式 的 图 片 ， 那 么 它 
原本 包含 的 一 部 分 数据 就 会 丢失 。 并 且 这 种 数据 的 丢失 通过 肉眼 是 可 以 察觉 到 的 。 这 种 格式 
不 适合 包含 简单 图 形 颜色 或 文字 的 图 片 。 

PNG 格式 是 指 “portable network graphics”， 这 种 图 片 格式 是 发 明 出 来 以 取代 GIF 格式 
的 。 同 样 的 图 片 使 用 PNG 格式 的 大 小 要 小 于 使 用 GIF 格式 的 大 小 。 这 种 格式 是 一 种 低 损 失 压 
缩 的 网 络 文件 格式 。 这 种 格式 的 图 片 适合 于 包含 文字 、 直 线 或 者 色 块 的 信息 。PNG 支持 透 
明 、 伽 马 校正 等 。 但 是 PNG 不 像 GIF 一 样 支持 动画 功能 。 并 且 下 6 不 支持 PNG 的 透明 功 


能 。 低 损 压缩 意味 着 压缩 比 不 高 ， 所 以 它 不 适合 用 于 照片 这 一 类 的 图 片 ， 否 则 文件 将 太 大 。 

GIF 是 指 “graphics interchange format” 它 也 是 一 种 低 损 压 缩 的 格式 ， 适 合用 于 包含 文 
字 、 直 线 或 者 色 块 信息 的 图 片 。 它 使 用 的 是 24 位 RGB 色彩 中 的 256 色 。 由 于 色彩 有 限 ， 所 
以 也 不 适合 用 于 照片 一 类 的 大 图 片 。 对 于 其 适合 的 图 片 ， 它 具有 不 丧失 图 片 质量 却 能 大 幅 压 
缩 的 图 片 大 小 的 优势 。 另 外 ， 它 支持 动画 。 


疑问 2: 如 何 选择 自己 想 要 的 RGB 颜色 呢 ? 


可 以 使 用 Photoshop 里 面 的 颜色 选取 工具 。 如 果 使 用 的 是 Linux 系统 ， 可 以 使 用 开源 的 工 
具 GIMP 中 的 颜色 选取 工具 。 
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MySQL 是 一 个 小 型 关系 数据 库 管 理 系统 ， 与 其 他 大 型 数据 库 管 理 系 统 (例如 
Oracle、DB2、SQL Server 等 ) 相 比 ，MySQL 规模 小 、 功 能 有 限 ， 但 是 它 体积 小 、 
速度 快 、 成 本 低 ， 且 提供 的 功能 对 稍微 复杂 的 应 用 来 说 已 经 够 用 ， 这 些 特性 使 得 
MySQL 成 为 世界 上 最 受 欢迎 的 开放 源 代 码 数据 库 。MYyYSQL 支持 多 种 平台 下 工作 。 
在 Windows 平台 下 可 以 使 用 二 进 制 的 安装 软件 包 或 免 安装 版 的 软件 包 进行 安装 ， 
二 进 制 的 安装 包 提供 了 图 形 化 的 安装 向 导 ， 免 安装 版 直接 解压 缩 即 可 以 使 用 。 

本 书 以 当前 最 新 版 本 MySQL 5.6 为 例 进行 讲解 ， 主 要 讲述 MySQL 服务 器 的 一 
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13.1 什么 是 MySQL 
本 节 将 介绍 MySQL 的 基本 知识 。 


13.1.1 客户 机 -服务 器 软件 


主 从 式 结构 (Client/Server Model) 或 客户 -服务 器 (Client/Server) 结 构 ， 简 称 C/S 结构 ， 是 一 
种 网 络 架 构 ， 通 常 在 该 网 络 架 构 下 ， 软 件 分 为 客户 (Client) 和 服务 器 (Server) 两 个 部 分 。 

服务 器 是 整个 应 用 系统 资源 的 存储 和 管理 中 心 ， 多 个 客户 端 则 各 自 处 理 相 应 的 功能 ， 共 
同 实现 完整 的 应 用 。 在 客户 /服务 器 结构 中 ， 客 户 端 用 户 的 请 求 被 传送 到 数据 库 服 务 器 ， 数 据 
库 服 务 器 进行 处 理 后 ， 将 结果 返回 给 用 户 ， 从 而 减少 了 网 络 数 据 传输 量 。 

用 户 使 用 应 用 程序 时 ， 首 先 启动 客户 端 ， 通 过 有 关 命 令 告知 服务 器 进行 连接 ， 以 完成 各 
种 操作 ， 而 服务 器 则 按照 此 请 示 提 供 相 应 的 服务 。 每 一 个 客户 端 软件 的 实例 都 可 以 向 一 个 服 
务 器 或 应 用 程序 服务 器 发 出 请 求 。 

这 种 系统 的 特点 ， 就 是 客户 端 和 服务 器 程序 不 在 同一 台 计 算 机 上 运行 ， 这 些 客户 端 和 服 
务 器 程序 通常 归属 不 同 的 计算 机 。 

主 从 式 架构 通过 不 同 的 途径 应 用 于 很 多 不 同类 型 的 应 用 程序 ， 例 如 ， 现 在 人 们 最 熟悉 的 
在 因特网 上 使 用 的 网 页 。 当 顾客 想 要 在 当当 网 站 上 买书 的 时 候 ， 电 脑 和 网 页 浏览 器 就 被 当 作 
一 个 客户 端 ， 同 时 ， 组 成 当当 网 的 电脑 、 数 据 库 和 应 用 程序 就 被 当 作 服 务 器 。 当 顾客 的 网 页 
浏览 器 向 当当 网 请 求 搜寻 数据 库 相 关 的 图 书 时 ， 当 当 网 服务 器 从 当当 网 的 数据 库 中 找 出 所 有 
该 类 型 的 图 书信 息 ， 结 合成 一 个 网 页 ， 再 发 送 回顾 客 的 浏览 器 。 服 务 器 端 一 般 使 用 高 性 能 的 
计算 机 ， 并 配合 使 用 不 同类 型 的 数据 库 ， 比 如 Oracle、Sybase 或 者 是 MySQL 等 ， 客 户 端 需 
要 安装 专门 的 软件 ， 比 如 浏览 器 。 


13.1.2 ”MySQL 版 本 


针对 不 同 用 户 ，MySQL 分 为 两 个 不 同 的 版 本 。 

e@ MySQL Community Server( 社 区 版 ): 该 版 本 完全 免费 ， 但 是 官方 不 提供 技术 支持 。 

@ MySQL Enterprise Server( 企 业 版 服务 器 ): 它 能 够 以 很 高 性 价 比 为 企业 提供 数据 仓库 
应 用 ， 支 持 ACID 事务 处 理 ， 提 供 完 整 的 提交 、 回 滚 、 崩 溃 恢 复 和 行 级 锁定 功能 。 
但 是 该 版 本 需 付费 使 用 ， 官 方 提 供电 话 技术 支持 。 


MySQL Cluster 主要 用 于 架设 集群 服务 器 ， 需 要 在 社区 版 或 企业 版 基础 上 使 用 。 


| 
过 提示 
MySQL 的 命名 机 制 由 3 个 数值 和 1 个 后 缀 组成， 例如 mysql-5.6.10。 


(1) 第 1 个 数值 5 是 主 版 本 号 ， 描 述 了 文件 格式 ， 所 有 版 本 5 的 发 行 版 都 有 相同 的 文件 
格式 。 
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(2) 第 2 个 数值 6 是 发 行 级 别 ， 主 版 本 号 和 发 行 级 别 组 合 在 一 起 便 构 成 了 发 行 序列 号 。 
(3) 第 3 个 数值 10 是 在 此 发 行 系列 中 的 版 本 号 ， 随 每 次 新 分 发 版 本 递增 。 通 常 选 择 已 经 
发 行 的 最 新 版 本 。 

在 MySQL 开发 过 程 中 ， 同 时 存在 多 个 发 布 系列 ， 每 个 发 布 处 在 成 熟 度 的 不 同 阶段 。 

。 ”MySQL 5.6 是 最 新 开发 的 稳定 (GA) 发 布 系列 ， 是 将 执行 新 功能 的 系列 ， 目 前 已 经 可 
以 正常 使 用 。 

e MySQL 5.5 是 比较 稳定 (GA) 的 发 布 系列 ， 只 针对 漏洞 修复 后 重新 发 布 ， 没 有 增加 会 
影响 稳定 性 的 新 功能 。 

e MySQL 5.1 是 前 一 稳定 发 布 系列 。 只 针对 严重 漏洞 修复 和 安全 修复 重新 发 布 ， 没 有 
增加 会 影响 该 系列 的 重要 功能 。 


mp 对 于 MySQL 4.1、4.0 和 3.23 等 低 于 5.0 的 老 版 本 ， 官 方 将 不 再 提供 支持 。 而 所 
有 发 布 的 MySQL(Current Generally Available Release) 版 本 已 经 经 过 严格 、 标 准 的 测 
试 ， 可 以 保证 其 安全 可 靠 地 使 用 。 针 对 不 同 的 操作 系统 ， 读 者 可 以 在 MySQL 官方 下 
载 页 面 (http://dev.mysql.com/downloads/) 下 载 到 相应 的 安装 文件 。 


13.1.3” MySQL 的 优势 


MySQL 的 主要 优势 如 下 。 

(1) 速度 : 运行 速度 快 。 

(2) 价格 : MySQL 对 多 数 个 人 用 来 说 是 免费 的 。 

(3) 容易 使 用 : 与 其 他 大 型 数据 库 的 设置 和 管理 相 比 ， 其 复杂 程度 较 低 ， 易 于 学 习 。 

(4) 可 移植 性 ， 能够 工作 在 众多 不 同 的 系统 平台 上 ， 例 如 Windows、Linux、Unix、Mac OS 
等 操作 系统 。 

(5) 丰富 的 接口 : 提供 了 用 于 C、C++、Eiffel、Java、Perl、PHP、 了 Python、Ruby 和 Tcl 
等 语言 的 API。 

(6) 支持 查询 语言 ，MySQL 可 以 利用 标准 SQL 语法 并 且 支 持 ODBC( 开 放 式 数 据 库 连 接 ) 
的 应 用 程序 。 

(7) 安全 性 和 连接 性 : 十 分 灵活 和 安全 的 权限 和 密码 系统 ， 人 允许 基于 主机 的 验证 。 连 接 
到 服务 器 时 ， 所 有 的 密码 传输 均 采 用 加 密 形式 ， 从 而 保证 了 密码 安全 。 并 且 由 于 MySQL 是 
网 络 化 的 ， 因 此 可 以 在 因特网 上 的 任何 地 方 访问 ， 提 高 了 数据 共享 的 效率 。 


13.2 ”启动 服务 并 登录 MySQL 数据 库 


用 户 可 以 下 载 MySQL 并 安装 ， 安 装 完毕 之 后 ， 需 要 启动 服务 器 进程 ， 不 然 客户 端 无 法 
连接 数据 库 ， 客 户 端 通过 命令 行 工具 登录 数据 库 。 本 节 将 介绍 如 何 启动 MySQL 服务 器 和 登 
录 MySQL 的 方法 。 
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案例 课堂 四 一 


13.2.1 启动 MySQL 服务 


在 前 面 的 配置 过 程 中 ， 已 经 将 MySQL 安装 为 Windows 服务 ， 当 Windows 启动 、 停 止 
时 ，MySQL 也 自动 启动 、 停 止 。 不 过 ， 用 户 还 可 以 使 用 图 形 服务 工具 来 控制 MySQL 服务 器 
或 从 命令 行使 用 Net 命令 。 
可 以 通过 Windows 的 服务 管理 器 查看 ， 具 体 的 操作 步骤 如 下 。 
单 击 “ 开 始 ” 菜 单 ， 在 弹出 的 菜单 中 选择 “运行 ”命令 ， 弹 出 “运行 ”对 话 
框 ， 如 图 13-1 所 示 。 


1 ”windows 村 恨 据 所 给 和 的 名 称 ,为 人 打开 相应 的 亿 序 
Ey 文件 夹 、 文档 或 Internet 资源 。 


打开 (O): 
轩 ”使 用 管理 权限 创建 此 任务 。 


图 13-1 “运行 ”对 话 框 


ET 在 “打开 ”文本 框 中 输入 “services.msc”， 单 击 “ 确 定 ” 按 钮 ， 弹 出 Windows 
的 服务 管理 器 窗口 ， 在 其 中 可 以 看 到 服务 名 为 “MySQL” 的 服务 项 ， 其 右边 的 状态 
为 “已 启动 ”， 表 明 该 服务 已 经 启动 ， 如 图 13-2 所 示 。 


停止 此 服务 DB NetMsmq Liste.。 Rece... 禁用 网 络 服务 
es ON 类 用 本 地 服务 
© NetTcp Listener... Rece... 禁用 本 地 服务 
BR NetTcp Port Sh.. Prov... 禁用 本 地 服务 
SS Netlogon 为 用 .… 手动 本 地 系统 
我 Network Access 网络. 手动 网 络 服务 
总 Network Connec... 管理 .。 已 启动 手动 本 地 系统 


图 13-2 服务 管理 器 窗口 


由 于 设置 了 MySQL 为 自动 启动 ， 在 这 里 可 以 看 到 ， 服 务 已 经 启动 ， 而 且 启 动 类 型 为 自 
动 。 如 果 没 有 “已 启动 ”字样 ， 说 明 MySQL 服务 未 启动 。 启 动 方法 为 : 单 击 “ 开 始 ” 菜 
单 ， 选 择 “ 运 行 ”命令 ， 在 弹出 的 “运行 ”对 话 框 中 输入 “cmd”， 按 Enter 键 ， 弹 出 命令 提 
示 符 界面 。 然 后 输入 “net start mysql”， 按 Enter 键 ， 就 能 启动 MySQL 服务 了 ， 停 止 
MySQL 服务 的 命令 为 “net stop mysql”， 如 图 13-3 所 示 。 


画 管理 员 : C\Windows\system32\cmd.exe 喇 旺 -| 区 到 


图 13-3 在 命令 行 中 启动 和 停止 MySQL 


| 提示 输入 的 MySQL 是 服务 的 名 字 。 如 果 读 者 的 MySQL 服务 的 名 字 是 DB 或 其 他 名 
SS 字 ， 应 该 输入 “net start DB” 或 其 他 名 称 。 


也 可 以 直接 双击 MySQL 服务 ， 弹 出 MySQL 属性 对 话 框 ， 在 其 中 通过 单 击 “ 启 动 ”或 
“停止 ”按钮 来 更 改 服务 状态 ， 如 图 13-4 所 示 。 


MySQL56 的 尾 性 (本 地 计算 机 ) 
常规 “| 登录 | 恢复 | 依存 关系 

服务 名 称 :J 

显示 名 称 MySQLSG 


指 述 


可 执行 文件 的 路 径 
“C:\Program Files\lySQL\NySQL Server 5.6\bin\nysald” -~-defav 


启动 类 型 EE): ”| 自动 > 


服务 状态 已 启动 
停止 加 暂停 中) 
当 从 此 处 启动 服务 时 ， 您 可 指定 所 适用 的 启动 参数 * 


13-4 ”MySQL 属性 对 话 框 


13.2.2 ”登录 MySQL 数据 库 


当 MySQL 服务 启动 完成 后 ， 便 可 以 通过 客户 端 来 登录 MySQL 数据 库 了 。 在 Windows 
操作 系统 下 ， 可 以 通过 两 种 方式 登录 MySQL 数据 库 。 
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课 


贬 
Ss 


1. 以 Windows 命令 行 方式 登录 


具体 的 操作 步骤 如 下 。 
ESD 单 击 “开始 ”菜单 ， 在 弹出 的 菜单 中 选择 “运行 ”菜单 命令 ， 弹 出 “运行 ”对 
话 框 ， 在 其 中 输入 “cmd” 命 令 ， 如 图 13-5 所 示 。 


二 运行 | 


Windows 将 根据 外 所 贸 7 
文件 夫 、 文 档 或 Internet 资源 .。 


入 的 名 称 ,为 您 打开 相应 的 程序 . 


0 


确定 取消 浏览 (B).… 


图 13-5 “运行 ”对 话 框 


单 击 “ 确 定 ” 按 钮 ， 出 现 DOS 窗口 ， 在 其 中 输入 以 下 命令 并 按 Enter 键 确认 (如 
图 13-6 所 示 ): 


cd C:\Program Files\MySQL\MySQL Server 5.6\bin\ 


本 管理 员 : C\Windows\system32\cemd.exe os en 


i 


nents ettings orycd C:\Program Files\MySQL\MySQL Server 5| 


ram Files\MySQL\MySQL Server 5-6\hbiny。 


:Wsers\Adninistrator> A, 


图 13-6 DOS 窗口 


在 DOS 窗口 中 可 以 通过 登录 命令 连接 到 MySQL 数据 库 ， 连 接 MySQL 的 命令 
格式 为 : 
mysql -h hostname -u username -p 
其 中 mysql 为 登录 命令 ，-h 后 面 的 参数 是 服务 器 的 主机 地 址 ， 在 这 里 ， 客 户 端 和 服务 器 
在 同一 台 机 器 上 ， 所 以 输入 localhost 或 者 卫 地 址 127.0.0.1，-u 后 面 跟 登录 数据 库 的 用 户 名 
称 ， 这 里 为 root，-p 后 面 是 用 户 登录 密码 。 
接 下 来 ， 输 入 如 下 命令 : 


mysql -h localhost -u root -p 


命 2 


按 下 Enter 键 ， 系 统 会 提示 输入 密码 “Enter password”， 这 里 输入 在 前 面 配置 向 导 中 自 
己 设置 的 密码 ， 验 证 正确 后 ， 即 可 登录 到 MySQL 数据 库 ， 如 图 13-7 所 示 。 


S Ea 


Windows\system32\cmd.exe 


图 13-7 Windows 命令 行 登录 窗口 


mm 当 窗口 中 出 现 如 图 13-7 所 示 的 说 明 信 息 ， 命 令 提示 符 变 为 “mysql>” 时 ， 表 明 


是 
提示 


六 已经 成 功 登录 MySQL 服务 器 了 ， 可 以 开始 对 数据 库 进行 操作 。 


2. 使 用 MySQL 命令 行 客 户 端 登录 


依次 选择 “开始 ”一 “所 有 程序 ”一 “MySQL” 一 “MySQL Server 5.6” 一 “MySQL 5.6 
Command Line Client” 菜 单 命令 ， 进 入 密码 输入 窗口 ， 如 图 13-8 所 示 。 


加 MysQL 5.6 Command Line Client - Un..[ 品 -| 回 -| 区 到 


图 13-8 MySQL 命令 行 客 户 端 登录 窗口 
输入 正确 的 密码 之 后 ， 就 可 以 登录 到 MySQL 数据 库 了 。 


13.2.3 配置 Path 变量 


在 前 面 登录 MySQL 服务 器 的 时 候 ， 不 能 直接 输入 mysql 登录 命令 ， 是 因为 没有 把 
MySQL 的 bin 目录 添加 到 系统 的 环境 变量 里 面 。 
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如 果 每 次 登录 都 输入 “cd C:\Program Files\MySQL\IMySQL Server 5.6\bin ”才能 使 用 
mysql 等 其 他 命令 工具 ， 是 比较 麻烦 的 。 
下 面 介绍 怎样 手动 配置 Path 变量 。 具 体操 作 步 又 如 下 。 
ED 在 桌面 上 右 击 “计算 机 ”图 标 ， 在 弹出 的 快捷 菜单 中 选择 “属性 ”菜单 命令 ， 
如 图 13-9 所 示 。 
EUPy 在 弹出 的 “系统 ”窗口 中 ， 单 击 “ 高 级 系统 设置 ”选项 ， 如 图 13-10 所 示 。 


[ET 
OO [sse fe 站 让 加 
NED RA BV) IRM Pm) 一 一 一 一 
©- 
查看 有 关 计 算 机 89 基 本 信息 
网 ea indow 硕 吉 
eda Windows 7 上 
© ER 版 和 所 各 四 2009 Micrczok Corporetion。 保守 所 有 积 利 。 
2 一 司 
mt 
Ha vindowm7 信 村 村 
Se 团 w ness 
SWpN a AMD Lthlonlim) HX2 245 proceseor 
PD 290 GHz 
Wndows Upete 二 AM 400 68 625 68 可 用 
EAI 中 Sa 2 
ok 各 没有 可 用 于 比重 直 六 闪 舱位 六 入 
图 13-9 “计算 机 ”的 快捷 菜单 图 13-10 “系统 ”窗口 


ET 弹出 “系统 属性 ”对 话 框 ， 选 择 “高 级 ”选项 卡 ， 如 图 13-11 所 示 。 
EEC 单 击 “环境 变量 ”按钮 ， 弹 出 “环境 变量 ”对 话 框 ， 在 “系统 变量 ”列表 中 选 
择 “Path” 变 量 ， 如 图 13-12 所 示 。 


[而 作 _ 高 到 天 六 保护 [运程 | 过 
要 进行 大 多 救 更 改 ， 您 尼 须 作为 管理 员 登 录 。 


Aaninistrater 的 用 户 交 量 0D) 


性 能 什 
视觉 效果 ， 处 理 器 计划 ， 内 存 使 用 ， 以 及 虚拟 内 存 WUSERPROFILEX\AppData\Local \Temp 
WUSERPEOFILEX\AppDat a\Local\Tenp 
用 户 配置 文件 
与 您 登录 有 关 的 成 面 设置 
设置 @@)..， 
启动 和 上 丰 障 恢复 
系统 自动、 系统 失败 和 i 同 试 信息 
设置 中- 
EL 


图 13-11 “系统 属性 ”对 话 框 13-12 “环境 变量 ”对 话 框 

EECRD) 单 击 “ 编 辑 ” 按 钮 ， 在 “编辑 系统 变量 ”对 话 框 中 ， 将 MySQL 应 用 程序 的 bin 
目录 (C:\Program Files\MySQLAMYSQL Server 5.6\bin) 添 加 到 变量 值 中 ， 用 分 号 将 其 与 
其 他 路 径 分 隔 开 ， 如 图 13-13 所 示 。 


变量 名 0 : Path 


变量 值 0) : “am Files\MySQL\MySQL Server 5.6\bin 


L 确定 | | 取消 
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13-13 “编辑 系统 变量 ”对 话 框 


ET 添加 完成 之 后 ， 单 击 “ 确 定 ” 按 钮 ， 这 样 就 完成 了 配置 Path 变量 的 操作 ， 然 后 
就 可 以 直接 输入 mysql 命令 来 登录 数据 库 了 。 


13.3 MySQL 数据 库 的 基本 操作 


本 节 将 详细 介绍 数据 库 的 基本 操作 。 S 


13.3.1 创建 数据 库 
创建 数据 库 是 在 系统 磁盘 上 划分 一 块 区 域 用 于 数据 的 存储 和 管理 ， 如 果 管理 员 在 设置 权 


A 


限 的 时 候 为 用 户 创建 了 数据 库 ， 则 可 以 直接 使 用 ， 否 则 ， 需 要 自己 创建 数据 库 。MySQL 中 创 
建 数据 库 的 基本 SQL 语法 格式 为 : 

CREATE DATABASE database name; 

database_name 为 要 创建 的 数据 库 的 名 称 ， 该 名 称 不 能 与 已 经 存在 的 数据 库 重 名 。 

【 例 13.1】 创 建 测试 数据 库 test_db， 输 入 语句 如 下 : 


CREATE DATABASE test db; 


13.3.2 ”查看 数据 库 


数据 库 创 建 好 之 后 ， 可 以 使 用 SHOW CREATE DATABASE 声明 查看 数据 库 的 定义 。 
【 例 13.2】 查 看 创建 好 的 数据 库 test_db 的 定义 ， 输 入 语句 如 下 : 


mysql> SHOW CREATE DATABASE test db\G 


认 交 各 宙 记 次 闪闪 志 宙 次 闪 记 妆 妆容 妆 妆 闪闪 上 记 妆 闪闪 次 关 。] 。 工 口 阿 冯 夫 交 记 妆 宙 次 次 妆 庙 灾 次 妆 妆 妆 闪 妆 志 妆 商 页 页 立 碳 闪闪 页 
Database: test db 

Create Database: CREATE DATABASE ‘test db /*!40100 DEFAULT CHARACTER SET 

BEES EX 

1 row in set (0.00 sec) 

可 以 看 到 ， 如 果 数 据 库 创建 成 功 ， 将 显示 数据 库 的 创建 信息 。 

再 次 使 用 SHOW DATABASES: 语 句 来 查看 当前 所 有 存在 的 数据 库 ， 输 入 语句 如 下 : 


mysql> SHOW databases; 
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| Database 1 


| information schema | 
| mysql 1 

| performance schema | 
| sakila 
| 
1 
| 


7 rows in set (0.05 sec) 


可 以 看 到 ， 列 表 中 包含 了 刚 创建 的 数据 库 test_db 和 其 他 已 经 存在 的 数据 库 的 名 称 。 


13.3.3 ”删除 数据 库 


删除 数据 库 是 将 已 经 存在 的 数据 库 从 磁盘 空间 上 清除 ， 清 除 之 后 ， 数 据 库 中 的 所 有 数据 
也 将 一 同 被 删除 。 删 除数 据 库 语句 和 创建 数据 库 的 命令 相似 ，MySQL 中 删除 数据 库 的 基本 语 
法 格式 为 : 


DROP DATABASE database name; 


database_name 为 要 删除 的 数据 库 的 名 称 ， 如 果 指 定 的 数据 库 不 存在 ， 则 删除 出 错 。 
【 例 13.3】 删 除 测试 数据 库 test_db， 输 入 语句 如 下 : 


DROP DATABASE test db; 


语句 执行 完毕 之 后 ， 数 据 库 test_db 将 被 删除 ， 再 次 使 用 SHOW CREATE DATABASE 声 
明 查 看 数据 库 的 定义 ， 结 果 如 下 : 


mysql> SHOW CREATE DATABASE test_db\G 
ERROR 1049 (42000): Unknown database 'test db' 
ERROR: 
No query specified 
执行 结果 给 出 一 条 错误 信息 “ERROR 1049 <42000>: Unknown database “test_db*””， 即 
数据 库 test_db 已 不 存在 ， 删 除 成 功 。 
Sm 使 用 DROP DATABASE 命令 时 要 非常 谨慎 ， 在 执行 该 命令 时 ，MySQL 不 会 给 出 
六 ”任何 提醒 确认 信息 ，DROP DATABASE 声明 删除 数据 库 后 ， 数 据 库 中 存储 的 所 有 数 
据 表 和 数据 也 将 一 同 被 删除 ， 而 且 不 能 恢复 。 


13.3.4 选择 数据 库 


用 户 创建 了 数据 库 后 ， 并 不 能 使 用 SQL 语句 操作 该 数据 库 ， 还 需要 使 用 USE 语句 选择 
该 数据 库 。 具 体 的 语法 如 下 : 


USE 数据 库 名 ; 
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【 例 13.4】 选 择 数据 库 test， 输 入 语句 如 下 : 


USE test; 


13.4 MySQL 数据 表 的 基本 操作 


本 章 将 详细 介绍 数据 表 的 基本 操作 ， 主 要 内 容 包 括 : 创建 数据 表 、 查 看 数据 表 结 构 、 修 
改 数据 表 、 删 除数 据 表 。 


13.4.1 创建 数据 表 


数据 表 属 于 数据 库 ， 在 创建 数据 表 之 前 ， 应 该 使 用 语句 “USE < 数据 库 名 >” 指 定 操作 是 
在 哪个 数据 库 中 进行 ， 如 果 没 有 选择 数据 库 ， 会 抛 出 “No database selected” 错 误 。 

创建 数据 表 的 语句 为 CREATE TABLE， 语 法 规则 如 下 : 

CREATE TABLE < 表 名 > 

( 


字段 名 1， 数 据 类 型 [ 列 级 别 约束 条 件 ] [默认 值 ] ， 
字段 名 2， 数 据 类 型 [ 列 级 别 约束 条 件 ] [默认 值 ] ， 


-OSAW 简 帐 周 冲 需 81 中 


[ 表 级 别 约束 条 件 ] 
Fa 
使 用 CREATE TABLE 创建 表 时 ， 必 须 指定 以 下 信息 : 
e@ ”要 创建 的 表 的 名 称 ， 不 区 分 大 小 写 ， 不 能 使 用 SQL 语言 中 的 关键 字 ， 如 DROP、 
ALTER、INSERT 等 。 
e ”数据 表 中 每 一 个 列 (字段 ) 的 名 称 和 数据 类 型 ， 如 果 创 建 多 个 列 ， 要 用 去 号 隔 开 。 
【 例 13.5】 创 建 员 工 表 tb_emp1， 结 构 如 表 13-1 所 示 。 
表 13-1 tb_emp1 表 的 结构 


字段 名 称 数据 类 型 备 注 
a 员工 编号 
name 员工 名 称 


deptId INT(11) 所 在 部 门 编号 
salary FLOAT 工资 
首先 创建 数据 库 ，SQL 语句 如 下 : 


CREATE DATABASE test db; 


选择 创建 表 的 数据 库 ，SQL 语句 如 下 : 


USE test _ db; 


创建 tb_empl 表 ，SQL 语句 为 : 
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CREATE TABLE tb empl 
( 

id INT(11), 

name VARCHAR (25), 
deptId INT(11), 
salary FLOAT 


语句 执行 后 ， 便 创建 了 一 个 名 称 为 tb_emp1 的 数据 表 ， 使 用 SHOW TABLES; 语 句 查 看 数 
据 表 是 否 创建 成 功 ，SQL 语句 如 下 : 


mysql> SHOW TABLES; 


十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 
| Tables in test db | 

+- 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 
| tb empl 

+- 一 一 -一 一 一 -一 一 一 一 一 一 一 一 一 一 一 一 一 十 


1 row in set (0.00 sec) 


可 以 看 到 ，test_db 数据 库 中 已 经 有 了 数据 表 tb_emp1， 数 据 表 创建 成 功 。 


13.4.2 ”查看 数据 表 的 结构 


使 用 SQL 语句 创建 好 数据 表 之 后 ， 可 以 查看 表 结 构 的 定义 ， 以 确认 表 的 定义 是 否 正确 。 
在 MySQL 中 ， 查 看 表 结 构 可 以 使 用 DESCRIBE 和 SHOW CREATE TABLE 语句 。 这 里 将 针 
对 这 两 个 语句 分 别 进行 详细 的 讲解 。 

DESCRIBE/DESC 语句 可 以 查看 表 的 字段 信息 ， 其 中 包括 字段 名 、 字 段 数据 类 型 、 是 否 
为 主键 、 是 否 有 默认 值 等 。 语 法 规则 如 下 : 


DESCRIBE 表 名 ; 
或 者 简写 为 : 
DESC 表 名 ; 


【 例 13.6】 使 用 DESCRIBE 查看 表 tb_emp1l 的 表 结 构 。 
查看 tb_emp1 表 结 构 ，SQL 语句 如 下 : 


mysql> DESC tb empl; 


全 详实 二 de 让 人 Ls 
| Field | Type | Null | Key | Default | Extra 
De 1 Ce EE ee 3 i 
| id | ET | YES | | NULL | 1 

| name | varchar(25) | YES | | NULL | 

Ll deptId | int (11) ves | | NULL | 1 

| salary | float VES 证 | NULL | | 

让 由 是 二 二 二 二 二 二 一 一 一 一 一 一 一 一 一 二 二 


其 中 ， 各 个 字段 的 含义 分 别 解释 如 下 。 
e NULL: 表示 该 列 是 否 可 以 存储 NULL 值 。 
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第 

e。 Key: 表示 该 列 是 否 已 编制 索引 。PRI 表示 该 列 是 表 主 键 的 一 部 分 ，UNI 表示 该 列 是 ”了 

UNIQUE 索引 的 一 部 分 ，MUL 表示 在 列 中 某 个 给 定 值 允许 出 现 多 次 。 

。 ”Default: 表示 该 列 是 否 有 默认 值 ， 如 果 有 的 话 值 是 多 少 。 区 

。 ”Extra: 表示 可 以 获取 的 与 给 定 列 有 关 的 附加 信息 ， 例 如 AUTO_INCREMENT 等 。 掌 

SHOW CREATE TABLE 语句 可 以 用 来 显示 创建 表 时 的 CREATE TABLE 语句 ， 语 法 格 

式 如 下 : 甸 

SHOW CREATE TABLE < 表 名 \G>; 
人 使 用 SHOW CREATE TABLE 语句 ， 不 仅 可 以 查看 表 创建 时 的 详细 语句 ， 而 且 还 


SS 、 可 以 查看 存储 引擎 和 字符 编码 。 


如 果 不 加 WG 参数， 显示 的 结果 可 能 非常 混乱 ， 加 上 参数 \G* 之 后 ， 可 使 显示 结果 更 加 直 
易于 查看 。 
【 例 13.7】 使 用 SHOW CREATE TABLE 查看 表 tb_empl 的 详细 信息 ，SQL 语句 如 下 : 


mysql> SHOW CREATE TABLE tb empl; 


当 


IGG 


| Table | Create Table 


| fruites, | CREATE TABLE "fruits” ‘《 

“£f id”char(10) NOT NULL, 

`“s id int(11) NOT NULL, 

“f name” char(255) NOT NULL, 

“上 price” decimal (8,2) NOT NULL, 

PRIMARY KEY (`f_ id`)， 

KEY ‘index name. (‘f name ), 

NEY "index id price” {££ Ta £ price ) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 | 


使 用 参数 \G’ 之 后 的 结果 如 下 : 


mysql> SHOW CREATE TABLE tb empl\G 
认 庙 商 商 灾 商 灾 次 实 次 庙 六 奖 关 闪闪 次 妆容 妆容 奖 商 实 闪 奖 类 ]】 。 开口 罗 六 娄 妆 妆 奖 奖 妆 记 妆 守 类 妆 类 次 类 次 闫 六 实 六 实 六 实 六 记 六 闪 
Table: tb empl 
Create Table: CREATE TABLE ‘tb empl. ( 
~id” int(11) DEFAULT NULL, 
‘name. varchar(25) DEFAULT NULL, 
“deptId’ int(11) DEFAULT NULL, 
“salary. float DEFAULT NULL 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 
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1 row in set (0.00 sec) 


13.4.3 ”修改 数据 表 结 构 
MySQL 是 通过 ALTER TABLE 语句 来 修改 表 结 构 的 ， 具 体 的 语法 规则 如 下 : 


ALTER[IGNORE] TABLE 数据 表 名 alter Speclo alter Specls ss 
其 中 alter_spec 定义 要 修改 的 内 容 ， 语 法 如 下 : 


RDD [COLUMN] create definition [FIRST|AFTER column name] // 添 加 新 字段 


| ADD INDEX [index name] (index col name,...) // 添 加 索引 名 称 

| ADD PRIMARY KEY (index col name,...) // 添 加 主键 名 称 

| RDD UNIQUE [index name] (index col name,...) // 添 加 唯一 索引 

| ALTER [COLUMN] col name{SET DEFAULT literal |DROP DEFAULT}// 修 改 字 段 名 称 
| CHANGE [COLUMN] old col name create definition / /修改 字 段 类 型 

| MODIFY [COLUMN] create definition // 添 加 子 句 定义 类 型 

| DROP [COLUMN] col name // 删 除 字段 名 称 

| DROP PRIMARY KEY // 删 除 主键 名 称 

| DROP INDEX idex name // 删 除 索引 名 称 

| RENAME [AS] new tbl name / /更改 表 名 


table options 


【 例 13.8】 将 数据 表 tb_deptl 中 name 字段 的 类 型 由 VARCHAR(22) 改 成 VARCHAR(30)。 
输入 如 下 SQL 语句 并 执行 : 


ALTER TABLE tb deptl1 MODIFY name VARCHAR(30); 


13.4.4 删除 数据 表 


删除 数据 表 就 是 将 数据 库 中 已 经 存在 的 表 从 数据 库 中 删除 。 注 意 ， 在 删除 表 的 同时 ， 表 
的 定义 和 表 中 所 有 的 数据 均 会 被 删除 。 因 此 ， 在 进行 删除 操作 前 ， 最 好 对 表 中 的 数据 做 个 备 
份 ， 以 免 产 生 无 法 挽回 的 后 果 。 

在 MySQL 中 ,使 用 DROP TABLE 可 以 一 次 删除 一 个 或 多 个 没有 被 其 他 表 关 联 的 数据 
表 。 语 法 格式 如 下 : 


DROP TABLE [IF EXISTS] 表 1, 表 2，..., 表 n; 


其 中 ，“ 表 nn” 指 要 删除 的 表 的 名 称 ， 后 面 可 以 同时 删除 多 个 表 ， 只 需 将 要 删除 的 表 名 依 
次 写 在 后 面 ， 相 互 之 间 用 逗号 隔 开 即 可 。 如 果 要 删除 的 数据 表 不 存在 ， 则 MySQL 会 提示 一 
条 错误 信息 “ERROR 1051 (42S02): Unknown table “ 表 名 *”。 参 数 “IF EXISTS” 用 于 在 删除 
前 判断 删除 的 表 是 否 存在 ， 加 上 该 参数 后 ， 再 删除 表 的 时 候 ， 如 果 表 不 存在 ，SQL 语句 可 以 
顺利 执行 ， 但 是 会 发 出 警告 (warning)。 

【 例 13.9】 删 除数 据 表 tb_dept2，SQL 语句 如 下 : 


DROP TABLE IE EXISTS tb dept2; 
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13.5 ”MySQL 语句 的 操作 
本 节 讲 述 MySQL 语句 的 基本 操作 
13.5.1 插入 记录 


使 用 基本 的 INSERT 语句 插入 数据 ， 要 求 指定 表 名 称 和 插入 到 新 记录 中 的 值 。 基 本 语法 
格式 为 : 


INSERT INTO table name(column list) VALUES (Value list); 


table_name 指定 要 插入 数据 的 表 名 ，column _list 指定 要 插入 数据 的 那些 列 ，value_list 指 
定 每 个 列 应 对 应 插入 的 数据 。 注 意 ， 使 用 该 语句 时 ， 字 段 列 和 数据 值 的 数量 必须 相同 。 

在 MySQL 中 ， 可 以 一 次 性 插入 多 行 记录 ， 各 行 记 录 直 接 由 去 号 分 隔 即 可 。 

【 例 13.10】 创 建 数据 表 tmp7， 定 义 数据 类 型 为 TIMESTAMP 的 字段 ts， 向 表 中 插入 值 
“19950101010101” ，“950505050505” ，“1996-02-02 02:02:02’ ， “97@03@03 03@03@03’， 
121212121212，NOW0O，SQL 语句 如 下 : 


CREATE TABLE tmp7 (ts TIMESTAMP); 

INSERT INTO tmp7(ts) values('19950101010101'), 
('950505050505°'), 
('1996-02-02 02:02:02')，, 
('97@03@03 03@03@03'), 
(121212121212), 
(NOW()); 


13.5.2 ”查询 记录 
MySQL 从 数据 表 中 查询 数据 的 基本 语句 为 SELECT 语句 。SELECT 语句 的 基本 格式 是 : 


SELECT 

{* | < 字段 列表 >} 

[ 
FROM < 表 1>,< 表 2>,... 
[WHERE < 表达 式 > 
[GROUP BY <group by definition>] 
[HAVING <expression> [{<operator> <expression>}...]] 
[ORDER BY <order by definition>] 
[LIMIT [<offset>,] <row count>] 

] 

SELECT [字段 1, 字段 2, ... ,字段 n] 

FROM [ 表 或 视图 ] 

WHERE [查询 条 件 ] ; 


其 中 ， 各 条 子 句 的 含义 如 下 。 


TOSAW 渍 性 启 罕 由 人 小 下 目 


251 久 


令 252 


PHP+MySQL 动 态 网 站 开发 


案例 课堂 »… 


e  {* | < 字段 列表 >}: 包含 星 号 通配符 和 字段 列表 ， 表 示 查 询 的 字段 ， 其 中 字段 列 至 少 
包含 一 个 字段 名 称 ， 如 果 要 查询 多 个 字段 ， 多 个 字段 之 间 用 逗号 隔 开 ， 最 后 一 个 字 
段 后 不 要 加 逗号 。 

e@ “FROM < 表 1>,< 表 2>...: 表 1 和 表 2 表示 查询 数据 的 来 源 ， 可 以 是 单个 或 者 多 个 。 

@ 。 WHERE: 该 子 句 是 可 选项 ， 如 果 选 择 该 项 ， 将 限定 查询 行 必须 满足 的 查询 条 件 。 

e@ GROUP BY < 字段 >: 该 子 句 告 诉 MySQL 如 何 显示 查询 出 来 的 数据 ， 并 按照 指定 的 
字段 分 组 。 

e@ [ORDER BY < 字段 >]: 该 子 句 告诉 MySQL 按 什么 样 的 顺序 显示 查询 出 来 的 数据 ， 
可 以 进行 的 排序 有 升序 (ASC)、 降 序 (DESC)。 

@ [LIMIT [<offset>,] <row count>]: 该 子 句 指明 每 次 显示 查询 出 来 的 数据 条 数 。 

【 例 13.11】 从 fruits 表 中 获取 f name 和 price 两 列 ，SQL 语句 如 下 : 


SELECT f name, f£ price FROM fruits; 


13.5.3 ”修改 记录 


表 中 有 数据 之 后 ， 接 下 来 可 以 对 数据 进行 更 新 操作 ，MySQL 中 使 用 UPDATE 语句 更 新 


表 中 的 记录 ， 可 以 更 新 特定 的 行 或 者 同时 更 新 所 有 的 行 。 基 本 语法 结构 如 下 : 


UPDATE table name 
SET column namel = valuel,column name2=value2,...,column namen=valuen 
WHERE (condition); 


column namel,column_name2,.…,column namen 为 指定 更 新 的 字段 的 名 称 ; valuel, 


value2,…,valuen 为 相对 应 的 指定 字段 的 更 新 值 ，condition 指定 更 新 的 记录 需要 满足 的 条 件 。 
更 新 多 个 列 时 ， 每 个 “ 列 - 值 ”对 之 间 用 去 号 隔 开 ， 最 后 一 列 之 后 不 需要 逗号 。 


【 例 13.12】 在 person 表 中 ， 更 新 id 值 为 11 的 记录 ， 将 age 字段 值 改 为 15， 将 name 字段 


值 改 为 LiMing，SQL 语句 如 下 : 


UPDATE person SET age = 15, name='LiMing' WHERE id = 11; 


13.5.4 删除 记录 


件 。 


件 


从 数据 表 中 删除 数据 使 用 DELETE 语句 ，DELETE 语句 允许 WHERE 子 句 指定 删除 条 
DELETE 语句 的 基本 语法 格式 如 下 : 


DELETE FROM table name [WHERE <condition>]; 
table_name 指定 要 执行 删除 操作 的 表 ; [WHERE <condition>] 为 可 选 参数 ， 指 定 删除 条 


如 果 没 有 WHERE 子 句 ，DELETE 语句 将 删除 表 中 的 所 有 记录 。 
【 例 13.13】 在 person 表 中 ， 删 除 id 等 于 11 的 记录 ，SQL 语句 如 下 : 


mysql> DELETE FROM person WHERE id = 117 
Query OK, 1 row affected (0.02 sec) 


13.6 MySQL 数据 库 的 备份 与 还 原 


MySQL 提供 了 多 种 方法 对 数据 进行 备份 和 还 原 。 本 节 将 介绍 数据 备份 和 数据 还 原 的 相关 
知识 。 


13.6.1 数据 备份 


数据 备份 是 数据 库 管理 员 非 常 重要 的 工作 。 系 统 意外 崩溃 或 者 硬件 的 损坏 都 可 能 导致 数 
据 库 的 丢失 ， 因 此 ，MySQL 管理 员 应 该 定期 地 备份 数据 库 ， 使 得 在 意外 情况 发 生 时 ， 尽 可 能 
减少 损失 。 这 里 将 介绍 数据 备份 的 3 种 方法 。 


1. 使 用 mysqldump 命令 备份 


mysqldump 是 MySQL 提供 的 一 个 非常 有 用 的 数据 库 备 份 工 具 。mysqldump 命令 执行 时 ， 
可 以 将 数据 库 备 份 成 一 个 文本 文件 ， 该 文件 中 实际 上 包含 了 多 个 CREATE 和 INSERT 语句 ， 
使 用 这 些 语 句 可 以 重新 创建 表 和 插入 数据 。 

mysqldump 备份 数据 库 语句 的 基本 语法 格式 如 下 : 


mysqldump -u user -h host -ppassword dbname [tbname， [tbname...]]> filename.sql 


user 表示 用 户 名 称 ，host 表示 登录 用 户 的 主机 名 称 ，password 为 登录 密码 ; dbname 为 需 
要 备份 的 数据 库 名 称 ，tbname 为 dbname 数据 库 中 需要 备份 的 数据 表 ， 可 以 指定 多 个 需要 备 
份 的 表 ; 右 箭头 符号 “>” 告 诉 mysqldump 将 备份 数据 表 的 定义 和 数据 写 入 备份 文件 ; 
filename.sql 为 备份 文件 的 名 称 。 

【 例 13.14】 使 用 mysqldump 命令 备份 数据 库 中 的 所 有 表 ， 执 行 过 程 如 下 。 

为 了 更 好 地 理解 mysqldump 工具 如 何 工作 ， 这 里 给 出 一 个 完整 的 数据 库 例子 。 首 先 登录 
MySQL， 按 下 面 的 数据 库 结 构 创 建 booksDB 数据 库 和 各 个 表 ， 并 插入 数据 记录 。 数 据 库 和 表 
定义 如 下 : 


CREATE DATABASE booksDB; 
use booksDB; 


CREATE TABLE books 
( 
bk id INT NOT NULL PRIMARY KEY, 
bk title VARCHAR(50) NOT NULL, 
copyright YEAR NOT NULL 
); 
INSERT INTO books 
VALUES (11078, 'Learning MySsQL', 2010), 
(11033, 'study Html', 2011), 
(11035, 'How to use php', 2003), 
(11072, 'Teach yourself javascript"', 2005), 
(11028, 'Learning C++', 2005), 
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(11069, 'MVYSQL professional', 2009), 
(11026, 'Guide to MyYSQL 5.6', 2008), 
(11041, 'Inside VC++', 2011) 7 


CREATE TABLE authors 
( 
auth id INT NOT NULL PRIMARY KEY, 
auth name VARCHAR(20), 
auth gender CHAR(1) 
); 
INSERT INTO authors 
VALUES (1001, 'Writerx' ,'f"'), 
(1002, "WriterA' ,'f'), 
(1003, "WriterB' ,'m'), 
(1004, "WriterCc"' ,'f'), 
(10117 "WriterD® sf")s 
(1012, "WriterE’' ,'m'), 
(1013, "WriterF' ,'m'), 
(1014, "WriterG' ,'f'), 
(1015, "WriterH' ,'f"'); 


CREATE TABLE authorbook 
( 
auth_ id INT NOT NULL, 
bk_id INT NOT NULL, 
PRIMARY KEY (auth id, bk id)， 
FOREIGN KEY (auth id) REFERENCES authors (auth id), 
FOREIGN KEY (bk _ id) REFERENCES books (bk _ id) 


INSERT INTO authorbook 
VALUES (1001, 11033), (1002, 11035), (1003, 11072), (1004, 11028), 
(1011, 11078), (1012, 11026), (1012, 11041), (1014, 11069); 


完成 数据 插入 后 ， 打 开 操作 系统 命令 行 输入 窗口 ， 输 入 备份 命令 如 下 : 


C:\> mysqldump -u root -p booksdb > C:/backup/booksdb 20130301.sql 
Enter password: ** 


输入 密码 之 后 ，MySQL 便 对 数据 库 进行 了 备份 ， 在 C:\backup 文件 夹 下 面 查看 刚才 备份 
过 的 文件 ， 使 用 文本 查看 器 打开 文件 ， 可 以 看 到 其 部 分 文件 内 容 大 致 如 下 : 


-- MySQL dump 10.13 Distrib 5.6.10, for Win32 (x86) 


-— Host: localhost Database: booksDB 


= 一 Server version 5.6.10 


/*!140101 SET QOLD CHARACTER SET CLIENT=@@CHARACTER SET CLIENT */; 
/*!140101 SET QOLD CHARACTER SET RESULTS=Q@@CHARACTER SET RESULTS */; 
/*!140101 SET @OLD COLLATION CONNECTION=@@COLLATION CONNECTION */; 


加 


/*140101 SET NAMES utf8 */; 

/*!140103 SET QOLD TIME ZONE=@@TIME ZONE */; 

/*!140103 SET TIME ZONE="'+00:00' */; 

/*!140014 SET @OLD UNIQUE CHECKS=@@UNIQUE CHECKS, UNIQUE CHECKS=0 */7 
/*!140014 SET @OLD FOREIGN KEY CHECKS=@@FOREIGN KEY CHECKS, FOREIGN KEY_ 
CHECKS=0 */; 

/*!140101 SET OLD SQL MODE=@@SQL MODE, SQL MODE= 

"NO AUTO VALUE ON ZERO' */; 

/*140111 SET OLD SQL NOTES=@@SQL NOTES, SQL NOTES=0 */; 


TDSAW 入 性 言 守 “机 el 小 和 鱼 


-- Table structure for table “authorbook 


DROP TABLE IF EXISTS “authorbook 7 
/*!40101 SET @saved cs client = echaracter_set_client */; 
/*!40101 SET character set client = utf8 */; 
CREATE TABLE ‘authorbook. ( 
“auth id” int(11) NOT NULL, 
‘bk id” int(11) NOT NULL, 
PRIMARY KEY (‘auth id’, bk id )v 
KEY ‘bk id’ (‘bk id`)， 
CONSTRAINT ‘authorbook ibfk 1” FOREIGN KEY (‘auth id*) 
REFERENCES ‘authors. (‘auth id`)， 
CONSTRAINT ‘authorbook ibfk 2° FOREIGN KEY (‘bk id`) 
REFERENCES ‘books. (‘bk id'`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 
/*!40101 SET character set client = @saved cs client */; 


多 HG 


-- Dumping data for table “authorbook 


LOCK TABLES “authorbook ”WRITE 

/*!140000 ALTER TABLE “authorbook ”DISRBLE KEYS */; 

INSERT INTO ‘authorbook. VALUES (1012,11026), (1004,11028), (1001,11033) 
(1002,11035), (1012, 11041), (1014,11069), (1003,11072), (1011,11078); 
/*!140000 ALTER TABLE “authorbook ”ENRBLE KEYS */; 

UNLOCK TABLES; 

- . -省 略 部 分 内 容 


/*140103 SET TIME ZONE=@OLD TIME ZONE */; 


/*!140101 SET SQL MODE=@OLD SQL MODE */; 

/*!140014 SET FOREIGN KEY CHECKS=@OLD FOREIGN KEY CHECKS */; 
/*!140014 SET UNIQUE CHECKS=@OLD UNIQUE CHECKS */; 

/*!140101 SET CHARACTER SET CLIENT=@OLD CHARACTER SET CLIENT */; 
/*!140101 SET CHARACTER SET RESULTS=@OLD CHARACTER SET RESULTS */; 
/*!140101 SET COLLATION CONNECTION=@OLD COLLATION CONNECTION */; 
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/*!140111 SET SQL NOTES=@OLD SQL NOTES */; 

-- Dump completed on 2011-08-18 10:44:08 

可 以 看 到 ， 备 份 文 件 包 含 了 一 些 信息 ， 文 件 开头 首先 表明 了 备份 文件 使 用 的 mysqldump 
工具 的 版 本 号 ; 然后 是 备份 账户 的 名 称 和 主机 信息 ， 以 及 备份 的 数据 库 的 名 称 ， 最 后 是 
MySQL 服务 器 的 版 本 号 ， 在 这 里 为 5.6.10。 

备份 文件 接 下 来 的 部 分 是 一 些 SET 语句 ， 这 些 语句 将 一 些 系统 变量 值 赋 给 用 户 定义 变 
量 ， 以 确保 被 恢复 的 数据 库 的 系统 变量 与 原来 备份 时 的 变量 相同 ， 例 如 : 


/*140101 SET BOLD CHARACTER SET CLIENT=@@CHARACTER SET CLIENT */; 


该 SET 语句 将 当前 系统 变量 character set client 的 值 赋 给 用 户 定义 变量 @old_character 
set_client。 其 他 变量 与 此 类 似 。 
备份 文件 的 最 后 几 行 MySQL 使 用 SET 语句 恢复 服务 器 系统 变量 原来 的 值 ， 例 如 : 


/*!140101 SET CHARACTER SET CLIENT=@OLD CHARACTER SET CLIENT */; 


该 语句 将 用 户 定 义 的 变量 @old_character_set_client 中 保存 的 值 赋 给 实际 的 系统 变量 
character_ set_client。 

备份 文件 中 的 “--” 字 符 开头 的 行为 注释 语句 ， 以 “/*1” 开 头 、“*/” 结 尾 的 语句 为 可 执 
行 的 MySQL 注释 ， 这 些 语句 可 以 被 MySQL 执行 ， 但 在 其 他 数据 库 管 理 系 统 中 将 被 作为 注释 
忽略 ， 这 可 以 提高 数据 库 的 可 移植 性 。 

另外 注意 到 ， 备 份 文件 开始 的 一 些 语句 以 数字 开头 ， 这 些 数字 代表 了 MySQL 版 本 号 ， 
这 些 数字 告诉 我 们 ， 这 些 语 句 只 有 在 指定 的 MySQL 版 本 或 者 比 该 版 本 高 的 情况 下 才能 执 
行 。 例 如 40101 表明 这 些 语 句 只 有 在 MySQL 版 本 号 为 4.01.01 或 更 高 的 条 件 下 才 可 以 被 执行 。 

在 前 面 介 绍 的 mysqldump 语法 中 介绍 过 ，mysqldump 还 可 以 备份 数据 中 的 某 个 表 ， 其 语 
法 格式 为 : 


mysqldump -u user -h host -p dbname [tbname, [tbname...]] > filename.sql 


tbname 表示 数据 库 中 的 表 名 ， 多 个 表 名 之 间 用 空格 隔 开 。 

备份 表 和 备份 数据 库 中 所 有 表 的 语句 中 不 同 的 地 方 在 于 ， 要 在 数据 库 名 称 dbname 之 后 指 
定 需要 备份 的 表 名 称 。 

【 例 13.15】 备 份 booksDB 数据 库 中 的 books 表 ， 输 入 语句 如 下 : 


mysqldump -u root -p booksDB books > C:/backup/books 20130301.sql 

该 语句 创建 名 称 为 books_20130301.sql 的 备份 文件 ， 文 件 中 包含 了 前 面 介绍 的 SET 语句 
等 内 容 ， 不 同 的 是 ， 该 文件 只 包含 books 表 的 CREATE 和 INSERT 语句。 

如 果 要 使 用 mysqldump 备份 多 个 数据 库 ， 需 要 使 用 --databases 参数 。 备 份 多 个 数据 库 的 
语句 格式 如 下 : 


mysqldump -u user -h host -p --databases [dbname, [dbname...]]> filename.sql 


使 用 --databases 参数 之 后 ， 必 须 指定 至 少 一 个 数据 库 的 名 称 ， 多 个 数据 库 名 称 之 间 用 空格 


隔 开 。 
【 例 13.16】 使 用 mysqldump 备份 booksDB 和 test 数据 库 ， 输 入 语句 如 下 : 


mysqldump -u root -pb --databases booksDB test > C:\backup\books testDB 
20130301.sql 


该 语句 创建 名 称 为 books testDB 20130301.sql 的 备份 文件 ， 文 件 中 包含 了 创建 两 个 数据 
库 booksDB 和 test_db 所 必须 的 所 有 语句 。 
另外 ， 使 用 --all-databases 参数 可 以 备份 系统 中 所 有 的 数据 库 ， 语 句 如 下 : 


mysqldump -u user -h host -p --all-databases > filename.sql 


使 用 参数 --all-databases 参数 时 ， 不 需要 指定 数据 库 名 称 。 
【 例 13.17】 使 用 mysqldump 备份 服务 器 中 的 所 有 数据 库 ， 输 入 语句 如 下 : 


mysqldump -u root -p --all-databases > C:/backup/alldbinMySQL.sql 


该 语句 创建 名 称 为 alldbinMySQL.sql 的 备份 文件 ， 文 件 中 包含 了 对 系统 中 所 有 数据 库 的 


备份 信息 。 
zp 在 服务 器 上 进行 备份 ， 并 且 表 均 为 MyISAM 表 时 ， 应 考虑 使 用 mysqlhotcopy， 
外 ”因为 这 可 以 更 快 地 进行 备份 和 恢复 。 


mysqldump 还 有 一 些 其 他 选项 可 以 用 来 指定 备份 过 程 ， 例 如 --opt 选项 ， 该 选项 将 打开 -- 
quick、--add-locks、--extended-insert 等 多 个 选项 。--opt 选项 可 以 提供 最 快速 的 数据 库 转 储 。 
mysqldump 的 其 他 常用 选项 如 下 。 


--add-drop-database: 在 每 个 CREATE DATABASE 语句 前 添加 DROP DATABASE 
语句 。 

--add-drop-tables: 在 每 个 CREATE TABLE 语句 前 添加 DROP TABLE 语句 。 
--add-locking: 用 LOCK TABLES 和 UNLOCK TABLES 语句 引用 每 个 表 转 储 。 重 载 
转 储 文件 时 插入 得 更 快 。 

--all 一 database,-A: 转 储 所 有 数据 库 中 的 所 有 表 。 与 使 用 --database 选项 相同 ， 在 命 
令 行 中 命名 所 有 数据 库 。 

--comments[=0|1]: 如 果 设 置 为 0， 则 禁止 转 储 文件 中 的 其 他 信息 ， 例 如 程序 版 本 、 服 务 
器 版 本 和 主机 。--skip-comments 与 --comments=0 的 结果 相同 。 默 认 值 为 1， 即 包括 额外 
信息 。 
--compact: 产生 少量 输出 。 该 选项 禁用 注释 并 启用 --skip-add-drop-tables、--no-set- 
names、--skip-disable-keys 和 --skip-add-locking 选项 。 

--compatible=name: 产生 与 其 他 数据 库 系统 或 旧 的 MySQL 服务 器 更 兼容 的 输出 。 值 
可 以 为 ansi、mysql323 、mysql40 、postgresql 、oracle 、mssql 、db2 、maxdb 、 
no_key_options、no_tables_options 或 者 no_field_options。 

--complete-insert,-c: 使 用 包括 列 名 的 完整 的 INSERT 语句 。 
---debug[=debug_options],-# [debug_options]: 写 调试 日 志 。 

--delete,-D: 导入 文本 文件 前 清空 表 。 

--default-character-set=charset: 用 charset 作为 默认 字符 集 。 若 没有 指定 ， mysqldump 
使 用 utf8。 
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--delete-master-logs: 在 主 复制 服务 器 上 ， 完 成 转 储 操作 后 删除 二 进 制 日 志 。 该 选项 
自动 启用 -master-data。 

--extended-insert,-e: 使 用 包括 几 个 VALUES 列表 的 多 行 INSERT 语法 。 这 样 使 转 储 
文件 更 小 ， 重 载 文 件 时 可 以 加 速 插入 。 

--flush-logs,-F: 开始 转 储 前 刷新 MySQL 服务 器 日 志文 件 。 要 求 RELOAD 权限 。 
--force,-f 在 表 转 储 过 程 中 ， 即 使 出 现 SQL 错误 也 继续 。 

--lock-all-tables,-x: 对 所 有 数据 库 中 的 所 有 表 加 锁 。 在 整体 转 储 过 程 中 通过 全 局 锁定 
来 实现 。 该 选项 自动 关闭 --single-transaction 和 --lock-tables。 

--lock-tables,-1: 开始 转 储 前 锁定 所 有 表 。 用 READ LOCAL 锁定 表 以 允许 并 行 插入 
MyISAM 表 。 对 于 事务 表 ( 例 如 InnoDB 和 BDB)，--single-transaction 是 一 个 更 好 的 
选项 ， 因 为 它 根本 不 需要 锁定 表 。 

--no-create-db,-n: 该 选项 禁用 CREATE DATABASE /*!32312 IF NOT EXISTS*/ 
db_name 语句 ， 如 果 给 出 --database 或 --all--database 选项 ， 则 包含 到 输出 中 。 
--no-create-info,-t: 只 导出 数据 ， 而 不 添加 CREATE TABLE 语句 。 

--no-data,-d: 不 写 表 的 任何 行 信息 ， 只 转 储 表 的 结构 。 

--opt: 该 选项 是 速记 ， 等 同 于 指定 --add-drop-tables--add-locking，--create-option，-- 
disable-keys--extended-insert，--lock-tables-quick 和 --set-charset。 它 可 以 快速 进行 转 储 
操作 并 产生 一 个 能 很 快 装 入 MySQL 服务 器 的 转 储 文件 。 该 选项 默认 开启 ， 但 可 以 
用 --skip-opt 禁用 。 要 想 禁用 -opt 启用 的 选项 ， 可 以 使 用 --skip 形式 ， 例 如 --skip-add- 
drop-tables 或 --skip-quick。 

--password[=password],-p[password]: 当 连 接 服务 器 时 使 用 的 密码 。 如 果 使 用 短 选 项 
形式 (-p)， 选 项 和 密码 之 间 不 能 有 空格 。 如 果 在 命令 行 中 --password 或 -p 选项 后 面 没 
有 密码 值 ， 则 提示 输入 一 个 密码 。 

--port=port_num,-P port_num: 用 于 连接 的 TCP/IP 端口 号 。 

--protocol={TCP | SOCKET | PIPE | MEMORY}: 使 用 的 连接 协议 。 

--replace,-r: --replace 和 --ignore 选项 控制 替换 或 负责 唯一 键 值 已 有 记录 的 输入 记录 的 
处 理 。 如 果 指 定 --replace， 新 行 替 换 有 相同 的 唯一 键 值 的 已 有 行 ;， 如 果 指 定 -- 
ignore， 已 有 的 唯一 键 值 的 输入 行 被 跳 过 。 如 果 不 指定 这 两 个 选项 ， 当 发 现 一 个 复制 
键 值 时 会 出 现 一 个 错误 ， 并 且 忽 视 文本 文件 的 剩余 部 分 。 

--silent,-s: 沉默 模式 。 只 有 出 现 错 误 时 才 输 出 。 

--socket=path,-S path: 当 连 接 localhost 时 使 用 的 套 接 字 文件 (为 默认 主机 )。 
--user=user_name,-uuser name: 当 连 接 服务 器 时 MySQL 使 用 的 用 户 名 。 

--verbose,-v: 宛 长 模式 。 打 印 出 程序 操作 的 详细 信息 。 

--version,-V: 显示 版 本 信息 并 退出 。 

--xml,- 义 : 产生 XML 输出 。 


mysqldump 提供 许多 选项 ， 包 括 用 于 调试 和 压缩 的 ， 在 这 里 只 是 列举 了 最 有 用 的 。 运 行 
帮助 命令 mysqldump --help， 可 以 获得 特定 版 本 的 完整 选项 列表 。 
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Dn 如 果 运 行 mysqldump 没有 --quick 或 --opt 选项 ，mysqldump 在 转 储 结果 前 将 整个 
六 结果 集 装 入 内 存 。 如 果 转 储 大 数据 库 可 能 会 出 现 问题 。 该 选项 默认 启用 ， 但 可 以 用 -- 
skip-opt 禁用 。 如 果 使 用 最 新 版 本 的 mysqldump 程序 备份 数据 ， 并 用 于 还 原 到 比较 旧 

版 本 的 MySQL 服务 器 中 ， 则 不 要 使 用 --opt 或 -e 选项 。 


2. 直接 复制 整个 数据 库 目 录 


因为 MySQL 表 保 存 为 文件 方式 ， 所 以 可 以 直接 复制 MySQL 数据 库 的 存储 目录 及 文件 进 
行 备 份 。MySQL 的 数据 库 目录 位 置 不 一 定 相同 ， 在 Windows 平台 下 ，MySQL 5.6 存放 数据 
库 的 目录 通常 默认 为 “C:\Documents and Settings\All Users\Application DataMySQL\IMySQL 
Server 5.6\data ”或 者 其 他 用 户 自 定义 目录 ; 在 Linux 平台 下 ， 数 据 库 目 录 位 置 通常 为 
Ararlib/mysql/， 不 同 Linux 版 本 下 目录 会 有 所 不 同 ， 读 者 应 在 自己 用 的 平台 下 查找 该 目录 。 

这 是 一 种 简单 、 快 速 、 有 效 的 备份 方式 。 要 想 保持 备份 的 一 致 性 ， 备 份 前 ， 需 要 对 相关 
表 执 行 LOCK TABLES 操作 ， 然 后 对 表 执 行 FLUSH TABLES。 这 样 当 复 制 数据 库 目 录 中 的 文 
件 时 ， 人 允许 其 他 客户 继续 查询 表 。 需 要 FLUSH TABLES 语句 来 确保 开始 备份 前 将 所 有 激活 的 
索引 页 写 入 硬盘 。 当 然 ， 也 可 以 停止 MySQL 服务 再 进行 备份 操作 。 

这 种 方法 虽然 简单 ， 但 并 不 是 最 好 的 方法 。 因 为 这 种 方法 对 InnoDB 存储 引擎 的 表 不 适 
用 。 使 用 这 种 方法 备份 的 数据 最 好 还 原 到 相同 版 本 的 服务 器 中 ， 不 同 的 版 本 可 能 不 兼容 。 


pr 在 MySQL 版 本 号 中 ， 第 一 个 数值 表示 主 版 本 号 ， 主 版 本 号 相同 的 MySQL 数据 
SS 库 文 件 格式 相同 。 


3. 使 用 mysqlhotcopy 工具 快速 备份 


mysqlhotcopy 是 一 个 Perl 脚本 ， 最 初 由 Tim Bunce 编写 并 提供 。 它 使 用 LOCK 
TABLES、FLUSH TABLES 和 cp 或 scp 来 快速 备份 数据 库 。 它 是 备份 数据 库 或 单个 表 的 最 快 
的 途径 ， 但 它 只 能 运行 在 数据 库 目 录 所 在 的 机 器 上 ， 并 且 只 能 备份 MyISAM 类 型 的 表 。 
mysqlhotcopy 在 Unix 系统 中 运行 。 

mysqlhotcopy 命令 的 语法 格式 如 下 : 


mysqlhotcopy db name 1, ... db name n /path/to/new directory 


db_name 1,.….,db_name n 分 别 为 需要 备份 的 数据 库 的 名 称 ;，/path/to/new_directory 指定 备 
份 文件 目录 。 
【 例 13.18】 使 用 mysqlhotcopy 备份 test 数据 库 到 /usr/backup 目录 下 ， 输 入 语句 如 下 : 


mysqlhotcopy -u root -p test /usr/backup 
要 想 执行 mysqlhotcopy， 必 须 可 以 访问 备份 的 表 文 件 ， 具 有 那些 表 的 SELECT 权限 、 
RELOAD 权限 (以 便 能 够 执行 ELUSH TABLES) 和 LOCK TABLES 权限 。 
5 mysqlhotcopy 只 是 将 表 所 在 的 目录 复制 到 另 一 个 位 置 ， 只 能 用 于 备份 MyISAM 
饼 和 ARCHIVE 表 。 备份 InoDB 类 型 的 数据 表 时 会 出 现 错误 信息 。 由 于 它 复 制 本 地 格 
式 的 文件 ， 故 也 不 能 移植 到 其 他 硬件 或 操作 系统 下 。 


a 


TDSAWN 简 帐 赔 浊 _ 山 84 波 


py A 


259 S 


条 260 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 »… 


13.6.2 ”数据 还 原 


管理 人 员 操作 的 失误 、 计 算 机 故障 以 及 其 他 意外 情况 ， 都 会 导致 数据 的 丢失 和 破坏 。 当 
数据 丢失 或 意外 破坏 时 ， 可 以 通过 还 原 已 经 备份 的 数据 尽量 减少 数据 丢失 和 破坏 造成 的 损 
失 。 本 节 将 介绍 数据 还 原 的 方法 。 


1. 使 用 mysql 命令 还 原 


对 于 已 经 备份 的 包含 CREATE、INSERT 语句 的 文本 文件 ， 可 以 使 用 mysql 命令 导入 到 
数据 库 中 。 本 小 节 将 介绍 用 mysql 命令 导入 SQL 文件 的 方法 。 

备份 的 SQL 文件 中 包含 CREATE、INSERT 语句 (有 时 也 会 有 DROP 语句 )。mysql 命令 
可 以 直接 执行 文件 中 的 这 些 语句 。 其 语法 如 下 : 


mysql -u user -p [dbname] < filename.sql 


user 是 执行 backup.sql 中 语句 的 用 户 名 ; -p 表示 输入 用 户 密码 ，dbname 是 数据 库 名 。 如 
果 filename.sql 文件 为 mysqldump 工具 创建 的 包含 创建 数据 库 语 句 的 文件 ， 则 执行 的 时 候 不 需 
要 指定 数据 库 名 。 

【 例 13.19】 使 用 mysql 命令 将 Ci\backup\booksdb_20130301.sql 文件 中 的 备份 导入 到 数据 
库 中 ， 输 入 语句 如 下 : 


mysql -u root -p booksDB < C:/backup/booksdb 20130301.sql 


执行 该 语句 前 ， 必 须 先 在 MySQL 服务 器 中 创建 booksDB 数据 库 ， 如 果 不 存 在 ， 恢 复 过 
程 将 会 出 错 。 命令 执行 成 功 之 后 ，booksdb_20130301.sql 文件 中 的 语句 就 会 在 指定 的 数据 库 中 
恢复 以 前 的 表 。 

如 果 已 经 登录 MySQL 服务 器 ， 还 可 以 使 用 source 命令 导入 SQL 文件 。source 语句 的 语 
法 如 下 : 


source filename 


【 例 13.20】 使 用 root 用 户 登录 到 服务 器 ， 然 后 使 用 source 导入 本 地 的 备份 文件 booksdb_ 
20110101.sql， 输 入 语句 如 下 : 
一 选择 要 恢复 到 的 数据 库 


mysql> use booksDB; 
Database changed 


一 -使 用 source 命令 导入 备份 文件 

mysql> source C:\backup\booksDB 20130301.sql 

命令 执行 后 ， 会 列 出 备份 文件 booksDB_20130301.sql 中 每 一 条 语句 的 执行 结果 。source 
命令 执行 成 功 后 ，booksDB_20130301.sql 中 的 语句 会 全 部 导入 到 现 有 数据 库 中 。 


mm 执行 source 命令 前 ， 必 须 使 用 use 语句 选择 数据 库 。 不然 ， 恢 复 过 程 中 会 出 现 


了 提示 
SS “ERROR 1046 (3D000): No database selected” 的 错误 。 


2. 直接 复制 到 数据 库 目录 


如 果 数 据 库 通 过 复制 数据 库 文件 备份 ， 就 可 以 直接 复制 备份 的 文件 到 MySQL 数据 目录 
下 实现 还 原 。 通 过 这 种 方式 还 原 时 ， 必 须 保存 备份 数据 的 数据 库 和 待 还 原 的 数据 库 服 务 器 的 
主 版 本 号 相同 。 而 且 这 种 方式 只 对 MyISAM 引擎 的 表 有 效 ， 对 于 InnoDB 引擎 的 表 不 可 用 。 

执行 还 原 以 前 ， 关 闭 mysql 服务 ， 将 备份 的 文件 或 目录 覆盖 MySQL 的 data 目录 ， 启 动 
mysql 服务 。 对 于 Linux/Unix 操作 系统 来 说 ， 复 制 完 文件 后 ， 需 要 将 文件 的 用 户 和 组 更 改 为 
mysql 运行 的 用 户 和 组 ， 通 常用 户 是 mysql， 组 也 是 mysql。 

3. mysqlhotcopy 快速 恢复 


mysqlhotcopy 备份 后 的 文件 也 可 以 用 来 恢复 数据 库 ， 在 MySQL 服务 器 停止 运行 时 ， 将 备 
份 的 数据 库 文件 复制 到 MySQL 存放 数据 的 位 置 (MySQL 的 data 文件 夹 )， 重 新 启动 MySQL 
服务 即 可 。 如 果 以 根 用 户 执行 该 操作 ， 必 须 指 定数 据 库 文件 的 所 有 者 ， 输 入 语句 如 下 : 


chown -R mysql.mysql /var/lib/mysql/dbname 

【 例 13.21】 从 mysqlhotcopy 复制 的 备份 恢复 数据 库 ， 输 入 语句 如 下 : 

cp -R /usr/backup/test usr/local/mysql/data 

执行 完 该 语句 ， 重 启 服 务 器 ，MySQL 将 恢复 到 备份 状态 。 

| 如 果 需 要 恢复 的 数据 库 已 经 存在 ， 则 在 使 用 DROP 语句 删除 已 经 存在 的 数据 库 之 


后 ， 恢 复 才能 成 功 .另外 ，MySQL 不 同 版 本 之 间 必须 兼容 ， 这 样 ， 恢 复 之 后 的 数据 
才 可 以 使 用 。 
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13.7 疑难 解 惑 


疑问 1: 每 一 个 表 中 都 要 有 一 个 主键 吗 ? 

并 不 是 每 一 个 表 中 都 需要 主键 ,一 般 如 果 多 个 表 之 间 进 行 连接 操作 时 ， 需 要 用 到 主键 。 
因此 并 不 需要 为 每 个 表 都 建立 主键 ， 而 且 有 些 情况 最 好 不 使 用 主键 。 

疑问 2: mysqldump 备份 的 文件 只 能 在 MYSQL 中 使 用 吗 ? 

mysqldump 备份 的 文本 文件 实际 是 数据 库 的 一 个 副本 ， 使 用 该 文件 不 仅 可 以 在 MySQL 中 
恢复 数据 库 ， 而 且 通 过 对 该 文件 进行 简单 修改 ， 还 可 以 在 SQL Server 或 者 Sybase 等 其 他 数据 
库 中 恢复 数据 库 。 这 在 某 种 程度 上 实现 了 数据 库 之 间 的 迁移 。 

疑问 3: 如 何 选择 备份 工具 ? 


直接 复制 数据 文件 是 最 为 直接 、 快 速 的 备份 方法 ， 但 缺点 是 基本 上 不 能 实现 增 量 备份 。 
备份 时 必须 确保 没有 使 用 这 些 表 。 如 果 在 复制 一 个 表 的 同时 服务 器 正在 修改 它 ， 则 复制 无 
效 。 备 份 文件 时 ， 最 好 关闭 服务 器 ， 然 后 重新 启动 服务 器 。 为 了 保证 数据 的 一 致 性 ， 需 要 在 
备份 文件 前 ， 执 行 以 下 SQL 语句 : 
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FLUSH TABLES WITH READ LOCK; 


也 就 是 把 内 存 中 的 数据 都 刷新 到 磁盘 中 ， 同 时 锁定 数据 表 ， 以 保证 复制 过 程 中 不 会 有 新 
的 数据 写 入 。 这 种 方法 备份 的 数据 恢复 也 很 简单 ， 直 接 复制 回 原来 的 数据 库 目 录 下 即 可 。 

mysqlhotcopy 是 一 个 Perl 程序 ， 它 使 用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 
来 快速 备份 数据 库 。 它 是 备份 数据 库 或 单个 表 的 最 快 途径 ， 但 它 只 能 运行 在 数据 库 文件 所 在 
的 机 器 上 ， 并 且 mysqlhotcopy 只 能 用 于 备份 MyISAM 表 。mysqlhotcopy 适合 于 小 型 数据 库 的 
备份 ， 数 据 量 不 大 ， 可 以 使 用 mysqlhotcopy 程序 每 天 进行 一 次 完全 备份 。 

mysqldump 将 数据 表 导 成 SQL 脚本 文件 ， 在 不 同 的 MySQL 版 本 之 间 升 级 时 相对 比较 合 
适 ， 这 也 是 最 常用 的 备份 方法 。mysqldump 比 直接 复制 要 慢 些 。 
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14.1 PHP 访问 MySQL 数据 库 的 一 般 步 骤 


对 于 一 个 通过 Web 访问 数据 库 的 工作 过 程 ， 一 般 分 为 如 下 几 个 步骤 。 

(1) 用 户 使 用 浏览 器 对 某 个 页 面 发 出 HTTP 请 求 。 

(2) 服务 器 端 接收 到 请 求 ， 发 送 给 PHP 程序 进行 处 理 。 

(3) PHP 解析 代码 。 在 代码 中 有 连接 MySQL 数据 库 的 命令 和 请 求 特定 数据 库 的 某 些 特 
定数 据 的 SQL 命令 。 根 据 这 些 代 码 ，PHP 打开 一 个 与 MySQL 的 连接 ， 并 且 发 送 SQL 命令 到 
MySQL 数据 库 。 

(4) MySQL 接收 到 SQL 语句 之 后 ， 加 以 执行 。 执 行 完毕 后 返回 执行 结果 到 PHP 程序 。 

(5) PHP 执行 代码 ， 并 根据 MySQL 返回 的 请 求 结果 数据 ， 生 成 特定 格式 的 HTML 文 
件 ， 且 传递 给 浏览 器 。HTML 经 过 浏览 器 泻 染 ， 就 得 到 用 户 请 求 的 展示 结果 。 


14.2 ”连接 数据 库 前 的 准备 工作 


默认 情况 下 ， 从 PHP 5 开始 ，PHP 不 再 自动 开启 对 MySQL 的 支持 ， 而 是 放 到 扩展 函数 
库 中 。 所 以 用 户 需要 在 扩展 函数 库 中 开启 MySQL 函数 库 。 

首先 ， 打 开 php.ini 文件 ， 找 到 “ :extension=php_mysql.dll”， 去 掉 该 语句 前 的 分 号 
“;”， 如 图 14-1 所 示 ， 保 存 php.ini 文件 ， 重 新 启动 IS 或 Apache 服务 器 即 可 。 


文件 (中 人 格式 (O) 前 看 (V) 帮助 (H) 

;extension=php_interbase. dll <^ 
;extension=php_ ap dll 

;extension= 
;extensio 


extension=php dl dll 

;extension=php_oci8. dll 

;extension=php_oci8 llg. dll 国 
;extension=php_openss]l. dll 

;extension=php_pdo_firebird. dll 

;extension=php_pdo_mssql. dll 

extension=php_pdo_mysql. dll 

;extension=php_pdo_oci. dll 

;extension=php_pdo_odbc. dll SS 
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14-1 修改 php.ini 文 件 
配置 文件 设置 完成 后 ， 可 以 通过 phpinfo0 函 数 来 检查 是 否 配 置 成 功 ， 如 果 显 示 出 的 PHP 
的 环境 配置 信息 中 有 MySQL 的 项 目 ， 就 表示 已 经 开启 了 对 MySQL 数据 库 的 支持 ， 如 图 14-2 
所 示 。 


全 


重 
国 衣 


册 满 岂 TDOSAW 答 注 dHd_ 志 y| 小 而 国 


Cent API [msand 5010- 20711020 — $4: 

version bapab scean reaen ease teas TSe33S 
mysqlalow Jocal_infile om on 
mysq allow -porsistont 加 加 
mysq connect timeout 加 回 
Imysql.default_host [no va [no value 
Imysql.default -password re vane evawe 
Imysql.default-port [ne vatve evawe 
mysqldefault_socket va van 
Imysal.detault_user ro vee [ro va 
Imys ql max inks rimted mr 
Imysal mav_persistent med [IEI 
mysql trace_mode 四 加 


7 


图 14-2 PHP 的 环境 配置 页 面 
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14.3 PHP 操作 MySQL 数据 库 
下 面 介 绍 PHP 操作 MySQL 数据 库 所 使 用 的 各 个 函数 的 含义 和 使 用 方法 。 


14.3.1 访问 MySQL 数据 库 


PHP 操作 MySQL 数据 库 是 通过 PHP 的 mysqli 类 库 完成 的 。 这 个 类 是 PHP 专门 针对 
MySQL 数据 库 的 扩展 接口 。 

下 面 以 通过 Web 向 user 数据 库 请 求 数据 为 例 ， 介 绍 如 何 使 用 PHP 函数 处 理 MySQL 数据 
库 数 据 。 具 体 步骤 如 下 。 

ED 在 网 址 主 目录 下 创建 phpmysql 文件 夹 。 

在 phpmysql 文件 夹 下 建立 htmlform.html 文件 ， 输 入 如 下 代码 : 


<html> 
<head> 
<title>Finding User</title> 
</head> 
<body> 
<h2>Finding users from mysql database.</h2> 
<form action="formhandler.php" method="post"> 
Fill user name: 
<input name="username" type="text" size="20"/> <br /> 
<input name="submit" type="submit" value="Find"/> 
</form> 
</body> 
</html> 
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在 phpmysql 文件 夹 下 建立 formhandler.php 文件 ， 输 入 如 下 代码 : 


<html> 
<head> 
<title>User found</title> 
</head> 
<body> 
<h2>User found from mysql database.</h2> 


<?php 
$username = $ POST['username']; 


if(!$username){ 
echo "Error: There is no data passed."7 
> 
3 
if(!get magic quotes gpc())i{ 
$username = addslashes ($username); 
@ $db = mysqli connect('localhost','root','753951','adatabase'); 
if(mysqli connect errno()){ 
echo "Error: Could not connect to mysql database."; 
exit; 
3 
$q = "SELECT * FROM user WHERE name = '".$username."™'"; 
$result = mysqli query($db,$q); 
$rownum = mysqli num rows ($result); 
for($i=0; $i<$rownum; $i++){ 
$row = mysqli fetch assoc($result); 
echo "Id:".$row['id']."<br />"; 
echo "Name:".$row['name']."<br />"; 
echo "Age:".$row['age']."<br />"; 
echo "Gender:".$row['gender']."<br />"; 
echo "Tnfot™ Fro0nL infol <br /> 
3 
mysqli free result ($result); 
mysqli close($db); 
?> 


</body> 

</html> 

运行 htmlform html， 结 果 如 图 14-3 所 示 。 

在 输入 框 中 输入 用 户 名 “lilili”， 单 击 Find 按钮 ， 将 跳 转 到 formhandler.php 页 

面 ， 并 且 返 回 请 求 结果 ， 如 图 14-4 所 示 。 

在 运行 本 实例 前 ， 用 户 可 以 参照 前 面 章节 的 知识 ， 在 MySQL 服务 器 上 创建 adatabase 数 
据 库 ， 添 加 数据 表 user， 然 后 添加 一 些 演示 数据 即 可 。 

在 下 面 的 小 节 中 ， 将 详细 分 析 此 案例 中 所 用 函数 的 含义 和 使 用 方法 。 


Finding Users from mysql database. 


Fill user name: 


图 14-3 “htmiform.html 页 面 
Sie ap-acxjsnaou， “上 


User found from mysql database. 


Info:She is a woman 


图 14-4 formhandler.php 页 面 


14.3.2 连接 MySQL 服务 器 


PHP 是 使 用 mysqli_connect() 函 数 连接 到 mysql 数据 库 的 。 
mysqli_connect() 函 数 的 格式 如 下 : 


mysqli_connect ('MYSQL 服务 器 地 址 '，' 用 户 名 ' ，' 用户 密 码 ' ，' 要 连接 的 数据 库 名 ' ) 
例如 ， 上 例 中 的 连接 语句 如 下 : 


$db = mysqli connect('localhost','root','753951', 'adatabase'); 


该 语句 就 是 通过 此 函数 连接 到 MySQL 数据 库 并 且 把 此 连接 生成 的 对 象 传递 给 名 为 $db 的 
变量 ， 也 就 是 对 象 gtb。 其 中 MYSQL 服务 器 地 址 为 ‘localhost*?， 用 户 名 为 “root*， 用 户 密码 为 
本 环境 root 设 定 密码 “753951”， 要 连接 的 数据 库 名 为 “adatabase”。 

默认 情况 下 ，MySQL 服务 的 端口 号 为 3360， 如 果 采 用 默认 的 端口 号 ， 可 以 不 用 指定 ， 
如 果 采 用 了 其 他 的 端口 号 ， 比 如 采用 1066 端口 ， 则 需要 特别 指定 ， 例 如 127.0.0.1:1066 表示 
MySQL 服务 于 本 地 机 器 的 1066 端口 。 
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其 中 localhost 换 成 本 地 地 址 或 者 127.0.0.1， 都 能 实现 同样 的 效果 。 


14.3.3 选择 数据 库 文件 


连接 到 数据 库 以 后 ， 就 需要 选择 数据 库 ， 只 有 选择 了 数据 库 ， 才 能 对 数据 表 进 行 相关 的 
操作 。 这 里 需要 使 用 函数 mysqli_select db0) 来 选择 。 它 的 格式 为 : 


mysqli_select _db (数据 库 服务 器 连接 对 象 ， 目 标 数据 库 名 ) 


在 14.3.1 小 节 实例 中 的 $Sdb = mysqli_connect(“localhost’,‘root*,“753951’,‘adatabase”); 语 句 已 
经 通过 传递 参数 值 ‘adatabase" 确 定 了 需要 操作 的 数据 库 。 如 果 不 传递 此 参数 ，mysqli_connect() 
函数 只 提供 “MYSQL 服务 器 地 址 ”,“ 用 户 名 ”和 “用 户 密码 ”一 样 可 以 连接 到 MySQL 数 
据 库 服务 器 并 且 以 相应 的 用 户 登 录 。 如 上 例 的 语句 变 为 gdb = mysqli_connect('localhost root ， 
“7539517): 一 样 是 可 以 成 立 的 。 

但 是 ， 在 这 样 的 情况 下 ， 就 必须 继续 选择 具体 的 数据 库 来 进行 操作 。 

如 果 把 上 例 的 formhandler.php 文件 中 的 如 下 语句 : 


@ $db = mysqli connect('localhost','root','753951', 'adatabase'); 

修改 为 以 下 两 个 语句 替代 : 

@ $db = mysqli connect('localhost','root','753951°'); 

mysqli select db($db,'adatabase'); 

程序 运行 效果 将 完全 一 样 。 

在 新 的 语句 中 mysqli_select_db($db,“adatabase): 语 句 确 定 了 “数据 库 服 务 器 连接 对 象 ” 为 
$db， 而 “目标 数据 库 名 ”为 “adatabase”。 


14.3.4 执行 SQL 语句 


使 用 mysqli_query0 函 数 执 行 SQL 语句 ， 需 要 向 此 函数 中 传递 两 个 参数 ， 一 个 是 MySQL 
数据 库 服 务 器 连接 对 象 ， 一 个 是 以 字符 串 表示 的 SQL 语句 。mysqli_query0 函 数 的 格式 如 下 : 
mysqli_query (数据 库 服 务 器 连接 对 象 ， SQL 语句 ) 


在 14.3.1 小 节 的 示例 中 ，mysqli query($db.$q): 语 句 中 就 表明 了 “数据 库 服务 器 连接 对 
象 ”为 gtb，“SQL 语句 ”为 8q， 而 $q 用 $q =“SELECT * FROM user WHERE name = “” 
$username.“”; 语 句 赋值 。 

更 重要 的 是 ，mysqli_query0 函 数 执行 SQL 语句 之 后 ， 会 把 结果 返回 。 上 例 中 就 是 返回 了 
结果 并 且 赋 值 给 $result 变量 。 


14.3.5 ”从 数组 结果 集中 获取 信息 
使 用 mysqli_fetch_ assoc0 函 数 从 数组 结果 集中 获取 信息 ， 只 要 确定 SQL 请 求 返回 的 对 象 


就 可 以 了 。 
所 以 $row = mysqli_fetch_assoc($result); 语 句 直接 从 $result 结果 中 取得 一 行 ， 并 且 以 关联 数 


| 


组 的 形式 返回 给 $row。 
由 于 获得 是 关联 数组 ， 所 以 在 读 取 数组 元 素 的 时 候 ， 是 要 通过 字段 名 称 来 确定 数组 元 素 
的 。 上 例 中 echo “Id:”.Srow[“id"].“<br />”; 语 句 就 是 通过 “id” 字 段 名 确定 数组 元 素 的 。 


14.3.6 ”从 结果 中 获取 一 行 作为 对 象 


使 用 mysqli_fetch_object0 函 数 从 结果 中 获取 一 行 作为 对 象 ， 同 样 是 确定 SQL 请 求 返回 的 
对 象 就 可 以 了 。 
把 14.3.1 小 节 示 例 中 的 如 下 程序 : 


for($i=0; $i<$rownum; $i++){ 
$row = mysqli fetch assoc ($result); 
echo "Id:" .Srow['id'] ."<br />"; 
echo "Name:".$row['name']."<br />"; 
echo "Age:".$row['age']."<br />"; 
echo "Gender:".$row['gender']."<br />"; 
echo "Info:".$row['info']."<br />"; 


} 
修改 如 下 : 


for ($i=0; $i<$rownum; $i++){ 
$row = mysqli fetch object ($result); 
echo "Id:".$row->id."<br />"; 
echo "Name:".$row->name."<br />"; 
echo "Age:".$row->age."<br />"; 
echo "Gender:".$row->gender."<br />"; 
echo "Info:".$row->info."<br />"; 


之 后 ， 程 序 的 整体 运行 结果 相同 。 不 同 的 是 ， 修 改 之 后 的 程序 采用 了 对 象 和 对 象 属性 的 
表示 方法 。 但 是 最 后 输出 的 数据 结果 是 相同 的 。 


14.3.7 ”获取 查询 结果 集中 的 记录 数 


使 用 mysqli_ num rows0 函 数 获取 查询 结果 包含 的 数据 记录 的 条 数 ， 只 需要 给 出 返回 的 数 
据 对 象 就 可 以 了 。 

例如 14.3.1 小 节 的 示例 中 ，$rownum = mysqli_num rows($result):; 语 句 查 询 了 Sresult 的 记 
录 的 条 数 ， 并 且 赋 值 给 Srownum 变量 。 然 后 程序 利用 这 个 条 数 的 数值 ， 实 现 了 一 个 for 循环 ， 
遍历 所 有 记录 。 


14.3.8 释放 资源 


释放 资源 的 函数 为 mysqli_free_ result0)， 函 数 的 格式 为 : 
mysqli free_result (SQL 请 求 所 返回 的 数据 库 对 象 ) 
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例如 ，14.3.1 小 节 示例 中 的 程序 在 一 切 操作 都 基本 完成 后 通过 mysqli_free_result($result); 
语句 释放 了 SQL 请 求 返 回 的 对 象 Sresult 所 占用 的 资源 。 


14.3.9 关闭 连接 


在 连接 数据 库 时 ， 可 以 使 用 mysqli_connect0 函 数 。 与 之 相对 应 ， 在 完成 了 一 次 对 服务 器 
的 使 用 的 情况 下 ， 需 要 关闭 此 连接 ， 以 免 出 现 对 MySQL 服务 器 中 数据 的 误 操 作 。 一 个 服务 
器 的 连接 也 是 一 个 对 象 型 的 数据 类 型 。 

mysqli_connect0 函 数 的 格式 为 : 

mysqli_connect (需要 关闭 的 数据 库 连 接 对 象 ) 


在 14.3.1 小 节 的 示例 程序 中 ，mysqli_close($db): 语 句 关 闭 了 $db 对 象 。 


14.4 ”查询 数据 信息 


本 案例 讲述 如 何 使 用 Select 语句 查询 数据 信息 。 有 具体 操作 步骤 如 下 。 
在 phpmysql 文件 夹 下 建立 文件 selectform.html， 并 且 输 入 代码 如 下 : 


<html> 
<head> 
<title>Finding User</title> 
</head> 
<body> 
<h2>Finding users from mysql database.</h2> 
<form action="selectformhandler.php" method="post"> 
Select gender: 
<select name="gender"> 
<option value="male">man</option> 
<option value="female">woman</option> 
</select><br /> 
<input name="submit" type="submit" value="Find"/> 
</form> 
</body> 
</html> 


在 phpmysql 文件 夹 下 建立 selectformhandler.php 文件 ， 并 且 输 入 如 下 代码 : 


<html> 
<head> 
<title>User found</title> 
</head> 
<body> 
<h2>User found from mysql database.</h2> 
<?php 
S$gender = $ POST['gender']; 
if(!$gender){ 
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echo "Error: There is no data passed."; 
exit; 

} 

if(!get magic quotes gpc()){ 
$gender = addslashes ($gender); 


@ $db = mysqli connect('localhost','root','"'753951°'); 
mysqli select dbl($db,'adatabase'); 
if(mysqli connect errno()){ 
echo "Error: Could not connect to mysql database.™; 
exit; 


EL 


} 

$q = "SELECT * FROM user WHERE gender = '".$gender."™'"; 

$result = mysqli query($db,$q); 

$rownum = mysqli num rows ($result); 

for($i=0; $i<$rownum; $i++){ 
$row = mysqli fetch assoc($result); 
echo "Id:".$row['id']."<br />"; 
echo "Name:".$row['name']."<br />"; 
echo "Age:".$row['age']."<br />"; 
echo "Gender:".$row['gender']."<br />"; 
eeho "Info Srowl "info]>"<br />" 

} 

mysqli free result ($result); 

mysqli close($db); 

2 

</body> 

</html> 


运行 selectform.html， 结 果 如 图 14-5 所 示 。 


Me Select gender: mm ~ 


图 14-5 selectform.html 的 运行 结果 
EC 单 击 Find 按钮 ， 页 面 跳 转 至 selectformhandler.php， 并 且 返 回 如 图 14-6 所 示 的 
信息 。 
这 样 ， 程 序 就 给 出 了 所 有 gender 为 female 的 用 户 信 息 。 
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文件 (F) ”篇 强 (E) ”可 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


User found from mysql database. 


Info:She is a 18 years old lady. 


折 100% ~ 


图 14-6 selectformhandler.php 返回 的 信息 


14.5 ”动态 添加 用 户 信息 


在 上 一 节 的 示例 中 ， 程 序 通 过 form 查询 了 特定 用 户 名 的 用 户 信息 。 下 面 将 使 用 其 他 SQL 
语句 来 实现 PHP 的 数据 请 求 。 

下 面 通过 使 用 adatabase 的 user 数据 库 表 格 ， 添 加 新 的 用 户 信息 。 

ED 在 phpmysql 文件 夹 下 建立 insertform.html 文件 ， 并 且 输入 如 下 代码 ; 


<html> 
<head> 
<title>Adding User</title> 
</head> 
<body> 
<h2>Adding users to mysql database.</h2> 
<form action="formhandler.php" method="post"> 
Select gender: 
<select name="gender"> 
<option value="male">man</option> 
<option value="female">woman</option> 
</select><br /> 
Fill user name: 
<input name="username" type="text" size="20"/> <br /> 
Fill user age: 
<input name="age" type="text" size="3"/> <br /> 
Fill user info: 
<input name="info" type="text" size="60"/> <br /> 
<input name="submit" type="submit" value="Add"/> 
</form> 


</body> 
</html> 


在 phpmysql 文件 夹 下 建立 insertformhandler.php 文件 ， 并 且 输 入 如 下 代码 : 


<html> 
<head> 
<title>User adding</title> 
</head> 
<body> 
<h2>adding new user.</h2> 
<?php 
$username = $ POST['username']; 
$gender = $ POST['gender']; 
$age = $ POST['age']7 
$info = $ POST['info']; 
if(!$username and !$gender and !$age and !$info){ 
echo "Error: There is no data passed."; 
exit; 
3 
if(!$username or !$gender or !$age or !$info){ 
echo "Error: Some data did not be passed."; 
exit; 
3 
if(!get magic quotes gpc())i{ 
$username = addslashes ($username); 
$gender = addslashes ($gender); 
$age = addslashes ($age); 
$info = addslashes ($info); 
3 
@ $db = mysqli connect('localhost','root','753951°'); 
mysqli select dbl($db,'adatabase'); 
if(mysqli connect errno()){ 
echo “Error: Could not connect to mysql database."; 
[村 
} 
$q = "INSERT INTO user( name, age, gender, info) 
VALUES ('$username',$age,'$gender', '$info')"; 
if(!mysqli query ($db, $9q)){ 
echo "no new user has been added to database."™; 
}else{ 
echo "New user has been added to database."; 
3 
mysqli close ($db); 
?> 
</body> 
</html> 


运行 insertform.html， 运 行 结果 如 图 14-7 所 示 。 
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Adding users to mysql database. 


Select gender: wm 

Fill] user name: Heime 
Fill user age: 1 

Fill user info: He is ayoumg boy.| 
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14-7 insertform .html 的 运行 结果 


单 击 Add 按钮 ， 页 面 跳 转 至 insertformhandlerphp， 并 返回 信息 结构 ， 如 图 14-8 
所 示 。 


Oe 2 -sox 纺 User found x 


文件 (篇 强 (E) 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


adding new user. 


New user has been added to database. 


图 14-8 insertformhandler.php 页 面 的 运行 结果 


这 时 数据 库 user 表格 中 就 添加 了 一 个 新 的 元 素 。 

案例 分 析 : 

(1) insertform.html 文件 中 建立 了 user 表格 中 除 “id” 外 每 个 字段 的 信息 输入 框 。 

(2) insertformhandler.php 文件 中 建立 MySQL 连接 ， 生 成 连接 对 象 等 操作 都 与 上 例 中 的 
程序 相同 。 只 是 改变 了 SQL 请 求 语句 的 内 容 为 $q=“INSERT INTO user(name, age, gender, info) 
VALUES(‘$username’,$age,“$gender”, “$info”)”; 插 入 语句 。 

(3) 其 中 name、gender、info 字段 为 字符 串 型 ， 所 以 *$usemame”、'$gender 、'$info 三 个 
变量 要 以 字符 串 形式 加 入 。 


14.6 疑难 解 惑 


疑问 1: 修改 php.ini 文 件 后 仍然 不 能 调用 MySQL 数据 库 怎 么 办 ? 


有 时 修改 php.ini 文件 不 能 保证 一 定 可 以 加 载 MySQL 函数 库 。 此 时 如 果 使 用 phpinfo0 函 
数 不 能 显示 MySQL 的 信息 ， 说 明 配 置 失败 了 。 重 新 按照 14.2 节 的 内 容 检查 配置 是 否 正确 ， 
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如 果 正 确 ， 则 把 PHP 安装 目录 下 的 libmysql.dll 库 文件 直接 复制 ， 然 后 拷贝 到 系统 的 system32 
目录 下 ， 然 后 重新 启动 IIS 或 Apache， 最 好 再 次 使 用 phpinfo0 进 行 验证 ， 即 可 看 到 MySQL 
信息 ， 表 示 此 时 已 经 配置 成 功 。 

疑问 2: 为 什么 应 尽量 省 略 MySQL 语句 中 的 分 号 ? 

在 MySQL 语句 中 ， 每 一 行 的 命令 都 是 用 分 号 (:) 作 为 结束 的 ， 但 是 ， 当 一 行 MySQL 被 插 
入 到 PHP 代码 中 时 ， 最 好 把 后 面 的 分 号 省 略 掉 。 这 主要 是 因为 PHP 也 是 以 分 号 作为 一 行 的 结 
束 的 ， 额 外 的 分 号 有 时 会 让 PHP 的 语法 分 析 器 搞 不 明白 ， 所 以 还 是 省 略 掉 为 好 。 在 这 种 情况 
下 ， 虽 然 省 略 了 分 号 ， 但 是 PHP 在 执行 MySQL 命令 时 会 自动 加 上 去 的 。 

另外 ， 还 有 一 个 不 要 加 分 号 的 情况 。 当 用 户 想 把 字段 竖 着 排列 显示 下 来 ， 而 不 是 像 通常 
的 那样 横着 排列 时 ， 可 以 用 G 来 结束 一 行 SQL 语句 ， 这 时 就 用 不 上 分 号 了 ， 例 如 : 


SELECT * FROM Paper WHERE USER _ ID 三 1G 
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HTTP Web 协议 是 无 状态 协议 ， 对 于 事务 处 理 没有 记忆 能 力 。 缺 少 状态 意味 着 
如 果 后 续 处 理 需 要 前 面 的 信息 ， 则 它 必 须 重 传 ， 这 样 可 能 导致 每 次 连接 传送 的 数据 
量 增 大 。 客 户 端 与 服务 器 进行 动态 交互 的 Web 应 用 程序 出 现 之 后 ，HTTP 无 状态 的 
特性 严重 阻碍 了 这 些 应 用 程序 的 实现 ， 毕 竟 交 互 是 需要 承前启后 的 ， 简 单 的 购物 车 
程序 也 要 知道 用 户 到 底 在 先前 选择 了 什么 商品 。 于 是 ， 两 种 用 于 保持 HTTP 连接 状 


态 的 技术 就 应 运 而 生 了 ， 一 个 是 Cookie， 而 另 一 个 则 是 Session。 其 中 Cookie 将 数 
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15.1 ”Cookie 的 基本 操作 


下 面 介 绍 Cookie 的 含义 和 基本 用 法 。 
15.1.1 什么 是 Cookie 


Cookie 常用 于 识别 用 户 。Cookie 是 服务 器 留 在 用 户 计算 机 中 的 小 文件 。 
Cookie 的 工作 原理 是 : 当 一 个 客户 端 浏览 器 连接 到 一 个 URL 时 ， 它 会 首先 扫描 本 地 储存 
的 Cookie， 如 果 发 现 其 中 有 与 此 URL 相关 联 的 Cookie， 将 会 把 它 返 回 给 服务 器 端 。 

Cookie 通常 应 用 于 以 下 几 个 方面 

e@ 在 页 面 之 间 传递 变量 。 因 为 浏览 器 不 会 保存 当前 页 面 上 的 任何 变量 信息 ， 如 果 页 面 
被 关闭 ， 则 页 面 上 的 所 有 变量 信息 也 会 消失 。 而 通过 Cookie， 可 以 把 变量 值 在 
Cookie 中 保存 下 来 ， 然 后 另外 的 页 面 就 可 以 重新 读 取 这 个 值 。 

@ ”记录 访客 的 一 些 信 息 。 利 用 Cookie， 可 以 记录 客户 曾经 输入 的 信息 ， 或 者 记录 访问 
网 页 的 次 数 。 

e@ ”通过 把 所 查看 的 页 面 存 放 在 Cookie 临时 文件 夹 中 ， 可 以 提高 以 后 的 浏览 速度 。 

用 户 可 以 通过 header 以 如 下 格式 在 客户 端 生成 Cookie: 


Set-cookie:NAME=VALUE; [expires=DATE; ] [path=PATH; ] [domain=DOMAIN NAME;] [secure] 


NAME 为 Cookie 名 称 ，VALUE 为 Cookie 的 值 ，expires=DATE 为 到 期 日 ，path=PATH、 
domain=DOMAIN_NAME 为 与 某 个 地 址 相对 应 的 路 径 和 域名 ，secure 表示 Cookie 不 能 通过 单 
一 的 HTTP 连接 传递 。 


15.1.2 创建 Cookie 


通过 PHP， 用 户 能 够 创建 Cookie。 创 建 Cookie 使 用 PHP 的 setcookie0 函 数 ， 它 的 语法 格 
式 如 下 : 


setcookie (名 称 , Cookie 值 , 到 期 日 ,路 径 ,域名 , secure) 
其 中 的 参数 与 Set-cookie 中 的 参数 意义 相同 。 
setcookieO 函 数 必须 位 于 <html> 标 签 之 前 。 


< 
本 提示 


在 下 面 的 例子 中 ， 将 创建 名 为 “user” 的 Cookie， 把 它 赋值 为 “Cookie 保存 的 值 ”， 并 且 
规定 了 此 Cookie 在 1 小 时 后 过 期 。 

【 例 15.1】( 示 例文 件 ch15\15.1.php) 

<?php 


setcookie ("user"， "Cookie 保存 的 值 "，time ()+3600); 
多 
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<html> 
<body> 
</body> 
</html> 


运行 上 述 程 序 ， 会 在 cookies 文件 夹 下 自动 生成 一 个 Cookie 文件 ， 有 效 期 为 1 个 小 时 ， 
在 Cookie 失效 后 ，Cookies 文件 将 自动 被 删除 。 


et 如 果 用 户 没有 设置 Cookie 的 到 期 时 间 ， 则 默认 立即 到 期 ， 即 在 关闭 浏览 器 时 会 


外 自动 删除 Cookie 数据 。 
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15.1.3 读 取 Cookie 


那么 ， 如 何 取 回 Cookie 的 值 呢 ? 在 PHP 中 ， 使 用 $_COOKIE 变量 取 回 Cookie 的 值 。 下 
面 通过 示例 讲解 如 何 取 回 上 面 创建 的 名 为 user 的 Cookie 的 值 ， 并 把 它 显示 在 页 面 上 。 

【 例 15.2】( 示 例文 件 ch15\15.2.php) 

<?php 

// 输出 一 个 cookie 

echo $ COOKIE["user"]; 

// 显示 所 有 的 Cookie 


print r($ COOKIE); 
> 


IGG 


程序 运行 效果 如 图 15-1 所 示 。 
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文件 (F) 。 移 锅 (E) 吾 看 V) 收藏 闪 ( 和 工具 (T) 帮助 (H) 


Cookie 保存 的 值 Array ( [user] => Cookie 保存 的 值 ) 


15-1 读 取 Cookie 


用 户 可 以 通过 isset0 函 数 来 确认 是 否 已 设置 了 Cookie。 下 面 通过 示例 来 讲解 。 
【 例 15.3】( 示 例文 件 ch15\15.3.php) 


<html> 

<body> 

<?php 

if (isset($ COOKIE["user"])) // 假 如 cookie 文件 存在 
echo "Welcome " . $ COOKIE["user"] . "!<br />"; 

else // 如 果 cookie 文件 不 存在 
echo "Welcome guest!<br />"; 

be 

</body> 

</html> 
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程序 运行 效果 如 图 15-2 所 示 。 


图 15-2 ”通过 isset() 函 数 来 确认 是 否 已 设置 了 Cookie 
NN 15.1.4 删除 Cookie 


常见 的 删除 Cookie 的 方法 有 两 种 ， 包 括 在 浏览 器 中 手动 删除 和 使 用 函数 删除 。 
1. 在 浏览 器 中 手动 删除 


由 于 Cookie 自动 生成 的 文本 会 存在 于 IE 浏览 器 的 cookies 临时 文件 夹 中 ， 在 浏览 器 中 删 
除 Cookie 文件 是 比较 快捷 的 方法 。 具 体 的 操作 步骤 如 下 。 
EEC 在 浏览 器 的 菜单 栏 中 选择 “工具 ”一 “Intemet 选项 ”命令 ， 如 图 15-3 所 示 。 


文件 站 旺 读 合理 (V)】 收 阅 于 WA) OH) 
和 REED olism oe 
Welcome Cookie 保存 的 npvate mg clsnittp 


图 15-3 选择 “Internet 选项 ”菜单 命令 


EU 弹出 “Intemet 选项 ”对 话 框 ， 然 后 在 “常规 ”选项 卡 中 单 击 “ 删 除 ” 按 钮 ， 如 
图 15-4 所 示 。 

革 BY 弹出 “删除 浏览 的 历史 记录 ”对 话 框 ， 选 中 Cookie 复 选 框 ， 单 击 “ 删 除 ” 按 钮 
即 可 ， 如 图 15-5 所 示 。 返 回 到 “Internet 选项 ”对 话 框 ， 单 击 “ 确 定 ” 按 钮 ， 即 可 完 
成 删除 Cookie 的 操作 。 
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[ 豫 0 ] [ 滞 四 | [和 人力] [ 畏 0 功 能 四 ] 
| 
图 15-4 “Internet 选项 ”对 话 框 图 15-5 “删除 浏览 的 历史 记录 ”对 话 框 
2. 使 用 函数 删除 


删除 Cookie 仍然 使 用 setcookie0 函 数 。 当 删除 cookie 时 ， 将 第 二 个 参数 设置 为 空 ， 第 三 
个 参数 的 过 期 时 间 设 置 为 小 于 系统 的 当前 时 间 即 可 。 

【 例 15.4】( 示 例文 件 ch15\15.4.php) 

<?php 

// 将 cookie 的 过 期 时 间 设 置 为 比 当前 时 间 减 少 10 秒 


setcookie ("user", "", time()-10); 
> 


在 上 面 的 代码 中 ，timeO 函 数 返回 的 是 当前 的 系统 时 间 ， 把 过 期 时 间 减 少 10 秒 ， 这 样 过 
期 时 间 就 会 变 成 过 去 的 时 间 ， 从 而 删除 Cookie。 如 果 将 过 期 时 间 设置 为 0， 则 也 可 以 直接 删 
除 Cookie。 


15.2 认识 Session 
下 面 介绍 Session 的 一 些 基 本 概念 和 使 用 方法 。 
15.2.1 什么 是 Session 


由 于 HTTP 是 无 状态 协议 ， 也 就 是 说 ，HTTP 的 工作 过 程 是 请 求 与 回应 的 简单 过 程 ， 所 以 
HTTP 没有 一 个 内 置 的 方法 来 储存 在 这 个 过 程 中 各 方 的 状态 。 例 如 ， 当 同一 个 用 户 向 服务 器 发 
出 两 个 不 同 的 请 求 时 ， 虽 然 服务 器 端 都 会 给 以 相应 的 回应 ， 但 是 它 并 没有 办 法 知道 这 两 个 动 
作 是 由 同一 个 用 户 发 出 的 。 

由 此 ， 会 话 (Session) 管 理应 运 而 生 。 通 过 使 用 一 个 会 话 ， 程 序 可 以 跟踪 用 户 的 身份 和 行 
为 ， 并 且 根据 这 些 状 态 数据 ， 给 用 户 以 相应 的 回应 。 


| 
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15.2.2 ”Session 的 基本 功能 


在 PHP 中 ， 每 一 个 Session 都 有 一 个 ID。 这 个 Session ID 是 一 个 由 PHP 随机 生成 的 加 密 
数字 。 这 个 Session ID 通过 Cookie 储存 在 客户 端 浏览 器 中 ， 或 者 直接 通过 URL 传递 至 客户 
端 ， 如 果 在 某 个 URL 后 面 看 到 一 长 串 加 密 的 数字 ， 这 很 有 可 能 就 是 SessionID 了 。 

Session ID 就 像 是 一 把 钥匙 ， 用 来 注册 到 Session 变量 中 。 而 这 些 Session 变量 是 储存 在 服 
务 器 端的 。Session ID 是 客户 端 唯一 存在 的 会 话 数 据 。 

使 用 Session ID 打开 服务 器 端 相 对 应 的 Session 变量 ， 跟 用 户 相关 的 会 话 数据 便 一 目 了 
然 。 默 认 情况 下 ， 在 服务 器 端的 Session 变量 数据 是 以 文件 的 形式 加 以 储存 的 ， 但 是 会 话 变量 
数据 也 经 常 通过 数据 库 进行 保存 。 


15.2.3 Cookie 与 Session 


在 浏览 器 中 ， 有 些 用 户 出 于 安全 性 的 考虑 ， 关 闭 了 其 浏览 器 的 Cookie 功能 ， 导 致 Cookie 
不 能 正常 工作 。 

使 用 Session 可 以 不 需要 手动 设置 Cookie，PHP Session 可 以 自动 处 理 。 可 以 使 用 会 话 管 
理 及 PHP 中 的 session_get cookie params() 函 数 来 访问 Cookie 的 内 容 。 这 个 函数 将 返回 一 个 
数组 ， 包 括 Cookie 的 生存 周期 、 路 径 、 域 名 、secure 等 。 它 的 格式 为 : 


session get cookie params (生存 周期 ， 路 径 ， 域名 ， secure) 


15.2.4 储存 Session ID 在 Cookie 或 URL 中 


PHP 默认 情况 下 会 使 用 Cookie 来 储存 Session ID。 但 是 如 果 客 户 端 浏览 器 不 能 正常 工 
作 ， 就 需要 用 URL 方式 传递 Session ID 了 。 把 php.ini 中 的 session.use_trans_sid 设置 为 启用 状 
态 ， 就 可 以 自动 通过 URL 来 传递 Session ID。 

不 过 ， 通 过 URL 传递 Session ID 会 产生 一 些 安全 问题 。 如 果 这 个 连接 被 其 他 用 户 拷贝 并 
使 用 ， 有 可 能 造成 用 户 判断 的 错误 。 其 他 用 户 可 能 使 用 Session ID 访问 目标 用 户 的 数据 。 

或 者 可 以 通过 程序 把 Session ID 储存 到 常量 SID 中 ， 然 后 通过 一 个 连接 传递 。 


15.3 会 话 管 理 


一 个 完整 的 会 话 包括 创建 会 话 、 注 册 会 话 、 使 用 会 话 和 删除 会 话 。 下 面 介绍 有 关 会 话 管 
理 的 基本 操作 。 


15.3.1 创建 会 话 


常见 的 创建 会 话 的 方法 有 3 种 。 包 括 PHP 自动 创建 、 使 用 session_start0) 函 数 创建 和 使 用 
session_register() 函 数 创建 。 
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1. PHP 自动 创建 


用 户 可 以 在 php.ini 中 设 定 session.auto_start 为 启用 。 但 是 ， 使 用 这 种 方法 的 同时 ， 不 能 
把 Session 变量 对 象 化 。 应 定义 此 对 象 的 类 必须 在 创建 会 话 之 前 加 载 ， 然 后 新 创建 的 会 话 才能 
加 载 此 对 象 。 


2. 使 用 session start(0) 浮 数 
这 个 函数 首先 会 检查 当前 是 否 已 经 存在 一 个 会 话 ， 如 果 不 存在 ， 它 将 创建 一 个 全 新 的 会 
话 ， 并 且 这 个 会 话 可 以 访问 超 全 局 变量 $_SESSION 数组 。 如 果 已 经 有 一 个 存在 的 会 话 ， 函 数 


会 直接 使 用 这 个 会 话 ， 加 载 已 经 注册 过 的 会 话 变量 ， 然 后 使 用 。 
session_start() 函 数 的 语法 格式 如 下 : 


bool session start(void); 
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2 session_startO) 函 数 必 须 位 于 <html> 标 签 之 前 。 


【 例 1$.5】( 示 例文 件 ch15\15.5.php) 


<?php session start() 7 ?> 

<html> 

<body> 

</body> 

</html> 

上 面 的 代码 会 向 服务 器 注册 用 户 的 会 话 ， 以 便 可 以 开始 保存 用 户 信息 ， 同 时 会 为 用 户 会 
话 分 配 一 个 UID。 


3. 使 用 session register() 函 数 

在 使 用 session_register0 函 数 之 前 ， 需 要 在 php.ini 文件 中 将 register_globals 设置 为 on， 然 
后 需要 重启 服务 器 。session_register() 函 数 通 过 为 会 话 登记 一 个 变量 来 隐 含 地 启动 会 话 。 
15.3.2 ”注册 会 话 变 量 

会 话 变量 被 启动 后 ， 全 部 保存 在 数组 $ SESSION 中 。 用 户 可 以 通过 对 $_SESSION 数组 赋 
值 来 注册 会 话 变量 。 

例如 ， 启 动 会 话 ， 创 建 一 个 Session 变量 ， 并 赋予 “xiaoli” 的 值 ， 代 码 如 下 : 


多 A 


<?php 
session start (); // 启 动 session 
$_SESSION['name']='xiaoli'; // 声 明 一 个 名 为 name 的 变量 ， 并 赋值 ‘xiaol1i* 


Se 


这 个 会 话 变量 值 会 在 此 会 话 结束 或 被 注销 后 失效 ， 或 者 还 会 根据 php.ini 中 的 session.ge_ 
maxlifetime( 当 前 系统 设置 为 1440 秒 ， 也 就 是 24 小 时 ) 会 话 最 大 生命 周期 数 过 期 而 失效 。 
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15.3.3 ”使 用 会 话 变量 


使 用 会 话 变量 ， 首 先 要 判断 会 话 变量 是 否 存在 一 个 会 话 ID， 如 果 不 存在 ， 则 需要 创建 一 
个 ， 并 且 能 够 通过 $_ SESSION 变量 进行 访问 。 如 果 已 经 存在 ， 则 将 这 个 已 经 注册 的 会 话 变量 
载 入， 以 供用 户 使 用 。 

在 访问 $_SESSION 数组 时 ， 先 要 使 用 isset0 或 empty0 来 确定 $_ SESSION 中 会 话 变量 是 否 
为 空 。 


例如 : 

<?php 

if(!empty($ SESSION['session name'])) // 判 断 会 话 变量 是 否 为 空 
$ssvalue = $ SESSION['session name']; // 声 明 一 个 变量 并 赋值 
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下 面 通过 例子 来 讲解 存储 和 取 回 $_SESSION 变量 的 方法 。 
【 例 15.6】( 示 例文 件 ch15\15.6.php) 


<?php 

session start(); 

// 存 储 会 话 变量 的 值 
$_SESSION['views'] = 1; 
> 

<html> 

<body> 

<?php 

// 读 取 会 话 变量 的 值 

echo "浏览 量 =". $_sESSION['views']; 
人 

</body> 

</html> 

程序 运行 效果 如 图 15-6 所 示 。 


@ htpi/loc. 十 PD” BCX| localhost 


文件 (月 ” 编 强 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


图 15-6 存储 和 取 回 $_SESSION 变量 


| 


15.3.4 注销 和 销毁 会 话 变量 


注销 会 话 变量 使 用 unset0 函 数 就 可 以 ， 如 unset($_SESSION[mame”])( 不 再 需要 使 用 PHP 
4 中 的 session_unregister() 或 session unset() 了 )。 

unset0 〇 函数 用 于 释放 指定 的 Session 变量 ， 代 码 如 下 : 

<?php 

unset ($_ SESSION['views']); 

23> 

如 果 要 注销 所 有 会 话 变量 ， 只 需要 向 $ SESSION 赋值 一 个 空 数组 就 可 以 了 ， 例 如 
$_SESSION = array()。 注 销 完成 后 ， 使 用 session_destroy0 销 毁 会 话 即 可 ， 其 实 就 是 清除 相应 
的 Session ID 。 代 码 如 下 : 

<?php 


session destroy(); 
RR 
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15.4 ”综合 应 用 会 话 管理 


下 面 通过 一 个 综合 案例 ， 讲 述 会 话 的 综合 应 用 。 
在 网 站 根 目录 下 建立 一 个 session 文件 夹 。 
在 session 文件 夹 下 建立 opensession.php， 输 入 以 下 代码 并 保存 : 


<?php 

session start(); 

$_SESSION['name'] = "王小明 "; 

echo "会 话 变量 为 :".$ sEssION['name']; 
?> yy 

<a href='usesession.php'> 下 一 页 </a> 


在 session 文件 夹 下 建立 usesession.php 文件 ， 输 入 以 下 代码 并 保存 : 


<?php 

session start(); 

echo "会 话 变量 为 :".$_sEssION['name'] ."<br />"; 
echo $_ SESSION['name']- "你 好 。"; 

?> 

<a href='closesession.php'> 下 一 页 </a> 


在 session 文件 夹 下 建立 closesession.php 文件 ， 输 入 以 下 代码 并 保存 : 


<?php 
session start(); 
unset ($ SESSION['name']); 
if (isset($ SESSION['name']))1{ 
echo "会 话 变量 为 :"-$_SESSION['name']7 
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jelset 
echo "会 话 变量 已 注销 。"; 
. 
session destroy(); 
a 


运行 opensession.php 文件 ， 结 果 如 图 15-7 所 示 。 


会 话 变量 为 :王小明 了 


图 15-7 程序 初始 结果 
点 击 页 面 中 的 “下 一 页 ”链接 ， 运 行 结果 如 图 15-8 所 示 。 


、\ 会 话 变量 为 :王小明 
王小明 , 你 好 。 下 一 页 


图 15-8 点 击 链接 后 的 结果 
继续 点 击 页 面 中 的 “下 一 页 ”链接 ， 运 行 结果 如 图 15-9 所 示 。 


【¢ © Er Er rz 


文件 (篇 绢 (E) 查 帮 (V)】 收藏 交 (A) 工具 (T) 帮助 (H) 
会 话 变量 已 注销 - | 


图 15-9 会 话 变量 已 注销 


15.5 疑难 解 惑 


疑问 1: 如 果 浏 览 器 不 支持 Cookie， 该 怎么 办 ? 


如 果 应 用 程序 涉及 到 不 支持 Cookie 的 浏览 器 ， 不 得 不 采取 其 他 方法 在 应 用 程序 中 从 一 个 
页 面向 另 一 个 页 面 传递 信息 。 一 种 方式 就 是 从 表单 传递 数据 。 
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下 面 的 表单 在 用 户 单 击 提交 按钮 时 向 welcome.php 提交 用 户 输入 : 


<html> 

<body> 

<form action="welcome.php" method="post"> 
Name: <input type="text" name="name" /> 
Age: <input type="text" name="age" /> 
<input type="submit" /> 

</form> 

</body> 

</html> 


要 取 回 welcome.php 中 的 值 ， 可 以 使 用 如 下 代码 : 


<html> 

<body> 、 
Welcome <?php echo $ POsST["name"]; ?>.<br /> 

You are <?php echo $ POsST["age"]; ?> years old. 

</body> 


SS 
疑问 2: Cookie 的 生命 周期 是 多 久 ? 
如 果 Cookie 不 设 定 失效 时 间 ， 则 表示 它 的 生命 周期 为 未 关闭 浏览 器 前 的 时 间 段 ， 一 旦 浏 


A 


览 器 关闭 ，Cookie 会 自动 消失 。 

如 果 设 定 了 过 期 时 间 ， 那 么 浏览 器 会 把 Cookie 保存 到 硬盘 中 ， 在 超过 有 效 期 前 ， 用 户 打 
开 正 浏览 器 时 会 依然 有 效 。 

由 于 浏览 器 最 多 存储 300 个 Cookie 文件 ， 每 个 Cookie 文件 最 大 支持 4KB， 所 以 一 旦 超 
过 容量 的 限制 ， 浏 览 器 就 会 自动 随机 地 删除 Cookies。 
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PHP 的 数据 库 抽 象 类 的 出 现 是 PHP 发 展 过 程 中 重要 的 一 步 。PDO 扩展 为 PHP 
访问 数据 库 定义 了 一 个 轻 量 级 的 、 一 致 性 的 接口 ， 它 提供 了 一 个 数据 访问 抽象 层 ， 
这 样 ， 无 论 使 用 什么 数据 库 ， 都 可 以 通过 一 致 的 函数 执行 查询 和 获取 数据 。PDO 随 
PHP 5.1 发 行 ， 在 PHP 5.0 的 PECL 扩展 中 也 可 以 使 用 ， 但 无 法 运行 于 先前 的 PHP 
版 本 。 本 章 主要 讲述 PDO 数据 库 抽象 类 库 的 使 用 方法 。 
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16.1 认识 PDO 


随 着 PHP 应 用 的 快速 增长 和 通过 PHP 开发 跨 平台 应 用 的 普及 ， 使 用 不 同 的 数据 库 是 十 分 
常见 的 。PHP 需要 支持 MySQL、SQL Server 和 Oracle 等 多 种 数据 库 。 
如 果 只 是 通过 单一 的 接口 针对 单一 的 数据 库 编写 程序 ， 比 如 用 MySQL 函数 处 理 MySQL 
数据 库 ， 用 其 他 函数 处 理 Oracle 数据 库 ， 这 在 很 大 程度 上 增加 了 PHP 程序 在 数据 库 方面 的 灵 
活性 并 提高 了 编程 的 复杂 性 和 工程 量 。 
如 果 通 过 PHP 开发 一 个 跨 数 据 库 平台 的 应 用 ， 比 如 对 于 一 类 数据 需要 到 两 个 不 同 的 数据 
库 中 提取 数据 ， 在 使 用 传统 方法 的 情况 下 只 好 写 两 个 不 同 的 数据 库 连 接 程 序 ， 并 且 要 对 两 个 
数据 库 连 接 的 工作 过 程 进行 协调 。 
为 了 解决 这 个 问题 ， 程 序 员 们 开发 出 了 “数据 库 抽象 层 ”。 通 过 这 个 抽象 层 ， 把 数据 处 
理 业务 逻辑 和 数据 库 连 接 区 分 开 来 。 也 就 是 说 ， 不 管 PHP 连接 的 是 什么 数据 库 ， 都 不 影响 
PHP 程序 的 业务 逻辑 。 这 样 对 于 一 个 应 用 来 说 ， 就 可 以 采用 若干 个 不 同 的 数据 库 支 持 方案 。 
PDO 就 是 PHP 中 最 为 主流 的 实现 “数据 库 抽象 层 ” 的 数据 库 抽象 类 。PDO 类 是 PHP 5 
中 最 为 突出 的 功能 之 一 。 在 PHP 5 版 本 以 前 ，PHP 都 是 只 能 通过 针对 MySQL 的 类 库 、 针 对 
Oracle 的 类 库 、 针 对 SQL Server 的 类 库 等 实现 有 针对 性 的 数据 库 连 接 。 
PDO 是 PHP Data Objects 的 简称 ， 是 为 PHP 访问 数据 库 定 义 的 一 个 轻 量 级 的 、 一 致 性 的 
接口 ， 它 提供 了 一 个 数据 访问 抽象 层 ， 这 样 ， 无 论 使 用 什么 数据 库 ， 都 可 以 通过 一 致 的 函数 
执行 查询 和 获取 数据 。 
PDO 通过 数据 库 抽 象 层 实现 了 以 下 一 些 特性 。 
@ ”灵活 性 : 可 以 在 PHP 运行 期 间 ， 直 接 加 载 新 的 数据 库 ， 而 不 需要 在 新 的 数据 库 使 用 
时 ， 重 新 设置 和 编译 。 

e@ 面向 对 象 : 这 个 特性 完全 配合 了 PHP 5， 通 过 对 象 来 控制 数据 库 的 使 用 。 

e@ ”速度 极 快 ， 由 于 PDO 是 使 用 C 语言 编写 并 且 编 译 进 PHP 的 ， 所 以 比 那 些 用 PHP 编 
写 的 抽象 类 要 快 很 多 。 


16.2 PDO 的 安装 


由 于 PDO 类 库 是 PHP 5 自 带 的 类 库 ， 所 以 要 使 用 PDO 类 库 ， 只 须 在 php.ini 中 把 关于 
PDO 类 库 的 语句 前 面 的 注释 符号 去 掉 。 

首先 启用 extension=php_pdo.dll 类 库 ， 这 个 类 库 是 PDO 类 库 本 身 。 然 后 是 不 同 的 数据 库 
了 驱动 类 库 选项 。extension=php_pdo_mysql.dll 适用 于 MySQL 数据 库 的 连接 。 如 果 使 用 SQL 
Server， 可 以 启用 extension=php_pdo_mssql.dll 类 库 。 如 果 使 用 Oracle 数据 库 ， 可 以 启用 
extension=php_pdo_oci.dll。 除 了 这 些 ， 还 有 支持 PgSQL 和 SQLite 等 的 类 库 。 

本 机 环境 下 启用 的 类 库 为 extension=php_pdo.dll 类 库 和 extension=php_pdo_mysql.dll 类 库 。 
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16.3 ”使 用 PDO 操作 MySQL 


在 本 开发 环境 下 使 用 的 数据 库 是 MySQL， 所 以 在 使 用 PDO 操作 数据 库 之 前 ， 需 要 首先 
连接 到 MySQL 服务 器 和 特定 的 MySQL 数据 库 。 
这 个 操作 是 通过 PDO 类 库 内 部 的 构造 函数 来 完成 的 。PDO 的 构造 函数 的 结构 是 : 


PDO: :constuct (DSN, username, password, driver options) 


其 中 DSN 是 一 个 “数据 源 名 称 ”，username 是 接 入 数据 源 的 用 户 名 ，password 是 用 户 密 
码 ，driver_options 是 特定 连接 要 求 的 其 他 参数 。 

DSN 是 一 个 字符 串 ， 它 是 由 “数据 库 服务 器 类 型 ”、“ 数 据 库 服务 器 地 址 ”和 “数据 库 
名 称 ” 组 成 的 。 它 们 组 合 的 格式 为 : 

' 数 据 库 服务 器 类 型 :nost= 数 据 库 服务 器 地 址 ; dbname= 数 据 库 名 称 ' 


driver_options 是 一 个 数组 ， 它 有 很 多 选项 。 

@ PDO::ATTR_AUTOCOMMIT: 此 选项 定义 PDO 在 执行 时 是 否 注释 每 条 请 求 。 

@ PDO::ATTR_CASE: 通过 此 选项 ， 可 以 控制 在 数据 库 中 取得 的 数据 的 字母 的 大 小 
写 。 具 体 说 来 就 是 ， 可 以 通过 PDO::CASE_UPPER 使 所 有 读 取 的 数据 字母 变 为 大 
写 ， 可 以 通过 PDO::CASE LOWER 使 所 有 读 取 的 数据 字母 变 为 小 写 ， 可 以 通过 
PDO::CASE_NATURL 使 用 特定 的 在 数据 库 中 发 现 的 字段 。 

e@ PDO::ATTR_EMULATE PREPARES: 此 选项 可 以 利用 MySQL 的 请 求 缓存 功能 。 

e PDO::ATTR_ERRMODE: 使 用 此 选项 定义 PDO 的 错误 报告 模型 。 具 体 的 三 种 模式 
分 别 为 PDO::ERRMODE _EXCEPTION 异常 模式 、PDO::ERRMODE SILENT 沉默 模 
式 和 了 PDO::ERRMODE WARNING 警报 模式 。 

e PDO::ATTR ORACLE_NULLS: 此 选项 在 使 用 Oracle 数据 库 时 会 把 空 字符 串 转换 为 
NULL 值 。 一 般 情 况 下 ， 此 选项 默认 为 关闭 。 

e PDO::ATTR_PERSISTENT: 使 用 此 选项 来 确定 此 数据 库 连 接 是 否 可 持续 。 但 是 其 默 
认 值 为 false， 不 启用 。 

e@ PDO::ATTR_PREFETCH: 此 选项 确定 是 否 要 使 用 数据 库 的 prefetch 功能 。 此 功能 是 
在 用 户 取得 一 条 记录 操作 之 前 就 取得 多 条 记录 ， 以 准备 给 其 下 一 次 请 求 数据 操作 提 
供 数据 ， 并 且 减 少 了 执行 数据 库 请 求 的 次 数 ， 提 高 了 效率 。 

@ PDO::ATTR_TIMEOUT: 此 选项 设置 超时 时 间 的 秒 数 。 但 MySQL 不 支持 此 功能 。 

e PDO::DEFAULT FETCH MODE: 此 选项 可 以 设 定 默认 的 fetch 模型 ， 是 以 联合 数据 
的 形式 取得 数据 ， 或 以 数字 索引 数组 的 形式 取得 数据 ， 或 以 对 象 的 形式 取得 数据 。 
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16.3.1 连接 MySQL 数据 库 的 方法 
当 建立 一 个 连接 对 象 的 时 候 ， 只 需要 使 用 new 关键 字 ， 生 成 一 个 PDO 的 数据 库 连接 实例 
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即 可 。 例 如 ， 使 用 MySQL 作为 数据 库 生 成 一 个 数据 库 连 接 ， 代 码 如 下 : 


$dbconnect = new PDO('mysql:host=localhost;dbname=pdodatabase','root','753951'); 


16.3.2 ”使 用 PDO 时 的 try-catch 错误 处 理 结构 
使 用 PDO 经 常 是 伴随 着 PHP 5 中 的 ty-catch 异常 处 理 机 制 进行 的 。 例 如 : 


<?php 
try 1 
$dbconnect = 
new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951'); 
} catch (PDOException $exception) { 
echo "Connection error message: " . $exception->getMessage(); 


人 


由 于 使 用 这 样 的 结构 ，PDO 可 以 配合 其 他 的 对 象 属性 ， 获 得 更 多 的 信息 。 

以 下 案例 通过 对 数据 库 请 求 的 错误 处 理 来 说 明 此 结构 。 具 体 步骤 如 下 。 

在 MySQL 数据 库 中 建立 pdodatabase 数据 库 ， 并 且 在 SQL 编辑 框 中 执行 以 下 
SQL 语句 : 


CREATE TABLE IF NOT EXISTS “user ( 
“id’ int(10) NOT NULL AUTO INCREMENT, 
“name” varchar(30) DEFAULT NULL, 
“age ”int(10) NOT NULL, 
“gender ”varchar (10) NOT NULL, 
`~info” varchar (255) NOT NULL, 
PRIMARY KEY (id ) 
) ENGINE=MVYISAM DEFAULT CHARSET=utf8 AUTO INCREMENT=8 ; 


插入 数据 ，SQL 语句 如 下 : 


INSERT INTO ‘user. (‘id', name `， "age `， ‘gender’, ‘info‘) VALUES 
(1, 'wangxiaoming', 32, 'male', 'He is a man'), 

(2 “1 237 "female's "She i a Woman')y 

(3, 'fangfanfang', 18, 'female', 'She is a 18 years old lady.'), 
(7, 'liuxiaoyong', 17, 'male', 'He is a young boy.'); 


至 此 ， 数 据 库 pdodatabase 和 数据 库 表 格 user 以 及 其 中 的 数据 都 已 创建 。 
在 网 站 下 建立 pdodemo.php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 
$dbconnect = 
new PDO('mysql:host=localhost;dbname=pdodatabase', 'root',’' '); 
} catch (PDOException $exception) { 
echo "Connection error message: 


. $exception->getMessage(); 
于 


?> 


运行 pdodemo.php 网 页 ， 结 果 如 图 16-1 所 示 。 


名 httpi/loc. 国 DP- Bo Xl localhost x 0 
文人 妨 名 (E 喜 看 V) 收藏 夫 (A) 工具 TT 帮助 (H) 


Connection error message: SQLSTATE[HY000] [1045] Access denied 
for user "root' @ localhost” (using password: YES) 


态 100% ~ 


16-1 ”连接 错误 处 理 


案例 分 析 : 

(1) 由 于 创建 PDO 实例 的 过 程 中 没有 给 出 必要 的 password 的 参数 ，PDO 通过 try-catch 
结构 抛 出 了 错误 信息 。 

(2) 在 pdodemo.php 文件 中 ，catch(PDOException $exception) 弛 使 用 了 PDOException 
类 。 前 面 提 到 的 PDO::ATTR_ERRMODE 选项 的 PDO::ERRMODE _ EXCEPTION 异常 模式 是 
使 用 PDOException 类 来 抛 出 错误 信息 的 ， 如 果 有 错误 产生 ， 它 是 即时 终止 程序 执行 ， 并 输出 
错误 信息 。 这 个 类 在 此 程序 中 的 实例 是 $exception。 

以 上 是 建立 PDO 数据 库 连 接 发 生 错误 时 获取 错误 信息 。 那 么 如 果 SQL 请 求 在 执行 的 过 
程 中 出 错 ， 其 错误 信息 应 当 如 何 获取 呢 ? 看 下 面 的 例子 。 

在 网 站 下 建立 pdodemo2.php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 

$dbconnect = 

new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951°'); 

} catch (PDOException $exception) { 

echo "Connection error message: " . $exception->getMessage(); 
} 
$sqlquery = "SELECT * FROM users"; 
$dbconnect->exec($sqlquery); 
echo $dbconnect->errorCode()."<br />"; 
print r($dbconnect->errorInfo()); 
?> 


运行 pdodemo2.php 网 页 ， 结 果 如 图 16-2 所 示 。 

案例 分 析 : 

(1) $sqlquery 定义 了 SQL 请 求 语 句 。$dbconnect->exec($sqlquery): 通 过 $dbconnect 实例 的 
exec() 方 法 执行 $sqlquerY 的 SQL 请 求 语句 。 

(2) 由 于 $sqlquery 定义 的 SQL 请 求 语句 中 “users’ 不 正确 (应 为 “user’)， 所 以 $dbconnect-> 
errorCode(): 语 句 直接 输出 SQL 请 求 的 错误 代码 42S02， 表 示 目 标 数据 库 不 存在 。 


全 
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ez p- Bcx|@u 


文件 (F) ”久久 (E) ”查看 (V) 收藏 夫 (A) 工具 ” 


| 12」 => Table“pdodatabase. users’ 


42502 了 
Array ( [0] =》42S02 [1] => 1146 目 
doesn' t exist ) 


R100% ~ 


图 16-2 执行 时 错误 的 获取 


(3) $dbconnect->errorInfo(); 语 句 则 是 获得 错误 的 所 有 信息 ， 包 插 错 误 代码 。 但 是 由 于 类 
方法 error::Info0 返 回 的 是 一 个 数字 索引 数组 ， 所 以 使 用 print r0 显 示 。 此 数组 拥有 3 个 数组 元 
素 。 第 一 个 元 素 为 遵循 SQL 标准 的 状态 码 ， 第 二 个 元 素 为 遵循 数据 库 标 准 的 错误 代码 ， 第 三 
个 元 素 为 具体 的 错误 信息 。 

(4) 实例 $dbconnect 其 实 是 使 用 的 PDO 类 的 类 方法 PDOStatment::errorCode() 来 获得 SQL 
错误 代码 的 。 错 误 信息 则 是 通过 PDO 类 的 类 方法 PDOStatment:: errorInfo0 来 获得 的 。 


16.3.3 ”使 用 PDO 执行 SQL 的 选择 语句 


PDO 执行 SQL 的 选择 语句 会 返回 结果 对 象 。 可 以 通过 foreach 来 遍历 对 象 内 容 。 以 下 例 
子 对 此 予以 介绍 。 
在 网 站 下 建立 pdoselect.php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 

$dbconnect = 

new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951°'); 

} catch (PDOException S$exception) { 

echo "Connection error message: " . $exception->getMessage(); 
3 
$sqlquery = "SELECT * FROM user"; 
$result = $dbconnect->query ($sqlquery); 
foreach ($result as $row){ 

Sname = $row['name']; 

$gender = $row['gender']; 

$age = $row['age']; 

echo "user $name , is $gender ,and is $age years old. <br />"; 


} 


运行 网 页 ， 结 果 如 图 16-3 所 示 。 
案例 分 析 : 


(1) 这 里 ，$sqlquery 定义 了 SQL 请 求 语句 。$dbconnect->query($sqlquery):; 语 句 通 过 实例 
$dbconnect 的 query0 方 法 执行 $sqlquery 的 SQL 请 求 语句 。 在 执行 SQL 语句 的 Select 操作 的 
时 候 ， 一 定 要 使 用 query0 方 法 ， 而 不 能 使 用 执行 其 他 操作 时 使 用 的 exec0 方 法 。 


二 
售 294 


【¢ 问 钨 htpi/loc. 起 PD- BCX| localhost 


文件 (F) ”六 名 (E) 可 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


| user wangxiaoming , is male ,and is 32 years old. 
user lilili , is female ,and is 23 years old. 


user fangfanfang , is female ,and is 18 years old. 
user liuxiaoyong , is male ,and is 17 years old. 


16-3 ”执行 选择 语句 
(2) foreach($result as $row) 语 句 以 默认 的 方法 获取 $result， 返 回 数据 对 象 的 所 有 数据 ， 并 
且 以 关联 数组 的 形式 表现 出 来 。 


16.3.4 ”使 用 PDO 获取 返回 数据 的 类 方法 


当 使 用 select 语句 向 数据 库 请 求 数据 以 后 ，query() 方 法 会 返回 一 个 包含 所 有 请 求 数据 的 对 
象 。 如 何 对 这 个 对 象 的 数据 进行 读 取 操 作 ， 将 通过 下 面 的 类 方法 来 讲解 。 

通过 fetch0 方 法 读 取 请 求 所 返回 的 数据 对 象 中 的 一 条 记录 。PDOStatement::fetch() 类 方法 
在 实例 化 之 后 即 可 使 用 。 可 以 选择 fetch_style 的 选项 作为 其 参数 。 例 如 PDO::FETCH_ASSOC 
选项 是 把 返回 的 数据 读 取 为 关联 数组 。PDO::FETCH_NUM 选项 是 把 返回 的 数据 读 取 为 数字 
索引 数组 。PDO_FETCH BOTH 选项 是 把 返回 的 数据 读 取 为 数组 ， 包 括 数字 索引 数组 和 关联 
数组 。 PDO::FETCH_OBJ 选项 是 把 返回 的 数据 读 取 为 一 个 对 象 ， 不 同 字段 的 数据 作为 其 对 象 
属性 。 

通过 fetchAll0 方 法 读 取 请 求 所 返回 的 数据 对 象 的 所 有 记录 。 

下 面 通过 例子 来 讲解 fetch0 方 法 的 使 用 技巧 。 

ED 在 网 站 下 建立 pdofetch.php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 
$dbconnect = 
new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951°'); 
} catch (PDOException $exception) { 
echo "Connection error message: " . $exception->getMessage(); 
a 
$sqlquery = "SELECT * FROM User"7 
$result = $dbconnect->query ($sqlquery); 
$rownum = $result->rowCount () 7 
echo "There are total ".$rownum." users:<br />"; 
while ($row = $result->fetch(PDO::FETCH ASSOC)){ 
Sname = $row['name']; 
$gender = $row['gender']; 
$age = $row['age']; 
echo "user $name , is $gender ,and is $age years old. <br />"; 


a 
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> 


运行 pdofetch php， 结 果 如 图 16-4 所 示 。 


[< [Er EEC ET 


文件 (月 六 各 (E) 查看 (V) ”收藏 夫 (A) ”工具 (T) 帮助 (H) 


There are total 4 users: 
user wangxiaoming , is male ,and is 32 years old. 


user lilili ，is female ,and is 23 years old. 
user fangfanfang ，is female ,and is 18 years old. 
user liuxiaoyong ，is male ,and is 17 years old. 


16-4 ”pdofetch.php 的 运行 结果 


案例 分 析 : 

(1) 这 里 ，$sqlquery 定义 了 SQL 请 求 语句 。$dbconnect->query($sqlquery): 语 句 通过 实例 
$dbconnect 的 query0 方 法 执行 $sqlquery 的 SQL 请 求 语句 。 返 回 对 象 为 $result。 

(2) $row = $result->fetch(PDO::FETCH_ASSOC) 语 句 直接 以 关联 数组 的 方式 取得 $result 
的 一 条 记录 ， 并 且 赋 值 给 Srow。 

(3) 使 用 while 循环 按照 输出 格式 向 页 面 打印 。 

下 面 的 例子 介绍 fetchAll0 方 法 的 使 用 技巧 。 

EJ 在 网 站 下 建立 pdofetchall.php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 
$dbconnect = 
new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951'); 
} catch (PDOException $exception) { 
echo "Connection error message: " . $exception->getMessage(); 
$sqlquery = "SELECT * FROM user"; 
$result = $dbconnect->query ($sqlquery); 
$rownum = $result->rowCount () 7 
echo "There are total ".$rownum." users:<br />"; 
$rowall = $result->fetchAll (); 
foreach ($rowall as Srow) { 
$id = $row[0]; 
$name = $row[1]; 
S$gender = $row[3]; 
$age = $row[2]; 
$info = $row['info']; 
echo "ID: $id . User $name , is $gender ,and is $age years old. 
and info: $info<br />"; 


2 


缠 


运行 pdofetchall.php 网 页 ， 结 果 如 图 16-5 所 示 。 


大 hpylfioc.. 全 PD BCX|| localhost x vw 
文件 (F) ” 妨 句 (E) 。 坦 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


There are total 4 users: 

ID: 1 . User wangxiaoming , is male ,and is 32 years old and info: He is a man 
ID: 2 . User lilili ，is female ,and is 23 years old and info: She is a woman 
ID: 3 . User fangfanfang , is female ,and is 18 years old and info: She is a 
18 years old lady. 

ID: 7 . User liuxiaoyong , is male ,and is 17 years old. and info: He is a 
young boy. 
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图 16-5 ”pdofetchall.php 网 页 的 运行 结果 


案例 分 析 : RN 
(1) 这 里 ，$sqlquery 定义 了 SQL 请 求 语句 。$dbconnect->query($sqlquery); 语 句 通 过 实例 
$dbconnect 的 query0 方 法 执行 $sqlquery 的 SQL 请 求 语句 。 返 回 对 象 为 $result。rowCount() 方 NN 


法 返回 数据 对 象 的 记录 的 条 数 。 

(2) $rowall = $result->fetchAll(; 语 句 用 来 取得 $result 的 所 有 记录 ， 并 且 赋 值 给 $rowall。 
然后 使 用 foreach 循环 遍历 数组 元 素 。 

(3) 由 于 fetchAll0 方 法 是 读 取 $result 对 象 为 数字 索引 数组 和 关联 数组 两 种 类 型 ， 所 以 ， 
在 遍历 的 时 候 ， 可 以 使 用 两 种 方式 指定 数组 元 素 。 


16.3.5 ”使 用 PDO 执行 SQL 的 添加 、 修 改 语句 


用 PDO 执行 添加 和 修改 的 SQL 命令 不 同 于 Select 操作 。 以 下 例子 介绍 此 方面 的 知识 。 
在 网 站 下 建立 pdoinsertupdate php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 

$dbconnect = 

new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951°'); 

} catch (PDOException $exception) { 

echo "Connection error message: " . $exception->getMessage(); 
3. 
$sqlquery = "INSERT INTO user(id,name,age,gender, info) 

VALUES (NULL, 'zhangdaguang', '39', 'male'，'he is a middle-age male.')"; 
if($dbconnect->exec ($sqlquery)){ 

echo "A new record has been inserted.<br />"; 
! 
$sqlquery2 = "UPDATE user SET age='45' WHERE name='zhangdaguang'"; 
if($dbconnect->exec ($sqlquery2)){ 

echo "The record has been updated."; 

:| 


> 
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运行 pdoinsertupdate.php， 结 果 如 图 16-6 所 示 。 


ED 


A new record has been inserted. 
The record has been updated. 


图 16-6 ”pdoinsertupdate.php 的 运行 结果 


案例 分 析 : 

(1) $sqlquery 定义 了 Insert 请 求 语句 。$dbconnect->exec($sqlquery): 通 过 实例 $dbconnect 
的 exec0 方 法 执行 $sqlquery 的 SQL 请 求 语句 ， 若 正确 执行 ， 则 返回 相应 的 结果 。 

(2) $sqlquery2 定义 了 Update 语句 。$dbconnect->exec($sqlquery2); 通 过 实例 $dbconnect 的 
exec() 方 法 执行 $sqlquery 的 SQL 请 求 语句 ， 若 正确 执行 则 返回 相应 的 结果 。 


16.3.6 ”使 用 PDO 执行 SQL 的 删除 语句 


删除 一 个 记录 也 是 使 用 exec0 类 方法 。 下 面 通过 示例 来 讲解 这 方面 的 知识 。 
在 网 站 下 建立 pdodelete.php 文件 ， 输 入 如 下 代码 : 


<?php 
try { 

$dbconnect = 

new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951'); 

} catch (PDOException $exception) { 

echo "Connection error message: " . $exception->getMessage(); 
$sqlquery = "DELET FROM user WHERE name = 'zhangdaguang'"; 
if($dbconnect->exec ($sqlquery)){ 

echo "A new record has been deleted."; 
y 


2> 


运行 pdodelete.php， 结 果 如 图 16-7 所 示 。 


16-7 ”执行 删除 语句 
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案例 分 析 : 
$sqlquery 定义 了 Delete 请 求 语句 。$dbconnect->exec($sqlquery): 语 句 通过 实例 $dbconnect 
的 exec0 方 法 执行 $sqlquery 的 SQL 请 求 语句 ， 若 正确 执行 则 返回 相应 的 结果 。 


16.4 ”PDO 的 prepare 表述 


当 执 行 一 个 SQL 语句 时 ， 需 要 PDO 对 语句 进行 执行 。 正 常情 况 下 可 以 逐 句 执行 。 而 每 
执行 这 样 一 句 ， 都 需要 PDO 首先 对 语句 进行 解析 ， 然 后 传递 给 MySQL 来 执行 。 这 都 需要 
PDO 的 工作 。 如 果 是 不 同 的 SQL 语句 ， 则 这 是 必要 过 程 。 但 如 果 是 Insert 这 样 的 语句 ， 语 句 
结构 都 一 样 ， 只 是 每 一 项 具体 的 数值 不 同 ， 在 这 种 情况 下 PDO 的 prepare 表述 就 可 以 只 提供 
改变 的 变量 值 ， 而 不 改变 SQL 语句 ， 起 到 减少 解析 过 程 、 节 省 资源 、 提 高 效率 的 作用 。 


使 用 prepare 表述 需要 使 用 两 个 方法 ， 一 个 是 prepare() 方 法 ， 另 一 个 是 execute() 方 法 。 N 
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下 面 通过 例子 来 介绍 此 方面 的 知识 。 


SS 在 网 站 下 建立 pdoprepare.php 文件 ， 输 入 代码 如 下 : 
<?php 
try { 
$dbconnect = 
new PDO('mysql:host=localhost;dbname=pdodatabase', 'root','753951°'); 


A 


} catch (PDOException $exception) { 
echo "Connection error message: " . $exception->getMessage(); 
$sqlquery = "INSERT INTO user SET id = :id, name = :name, 
age = :age,gender = :gender ,info = :info "7 

$prepareddb = $dbconnect->prepare ($sqlquery); 
if($prepareddb->execute (array( 

':id'=> 'NULL', 
:name'=> 'lixiaoyun', 
:age'=> '16', 
:gender'=> 'female', 
:info'=> 'She is a school girl.')))1{ 
echo "A new user, lixiaoyun, has been inserted.<br />"; 


if($prepareddb->execute (array( 

:id'=> 'NULL', 

:name'=> 'liuxiaoyu', 

:age'=> '18', 

:gender'=> 'male', 

:info'=> "he is a school boy.')))t{ 

echo "A new user, liuxiaoyu, has been inserted.<br />"; 


. 


2 


运行 pdoprepare.php， 结 果 如 图 16-8 所 示 。 
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OS 优 htpi/loc. 入 PD" BOX| localhost 


文件 (有 ) ”篇 强 (E) ”可 看 (V) 收 茂 夫 (A) 工具 (T) 帮助 (H) 


A new user, lixiaoyun, has been inserted. 
A new user, liuxiaoyu, has been inserted. 


图 16-8 ”pdoprepare.php 的 运行 结果 


案例 分 析 : 

(1) $sqlquery 定义 了 Delete 请 求 语句 。 这 个 SQL 请 求 语句 定义 了 字段 的 变量 ， 如 id 
=:id、name= :name 等 。 

(2) $dbconnect->prepare($sqlquery) 语 句 使 用 prepare(0) 类 方法 表述 prepare， 并 且 赋 值 给 对 
象 $prepareddb 。$prepareddb->execute(array(..)) 语 句 使 用 execute0 类 方法 执行 SQL 语句 。 
execute() 类 方法 中 通过 一 个 数组 为 SQL 请 求 语句 中 定义 的 变量 赋值 。 其 中 变量 值 为 键 值 ， 具 
体 值 为 数组 元 素 。 

(3) $prepareddb->execute(array(...)) 语 句 可 以 很 方便 地 重复 进行 使 用 。 只 要 修改 数组 中 的 
元 素 值 即 可 。 


16.5 疑难 解 惑 


疑问 1: PDO 中 事务 如 何 处 理 ? 


在 PDO 中 同样 可 以 实现 事务 处 理 的 功能 ， 有 具体 使 用 方法 如 下 。 
(1) 开启 事务 : 使 用 beginTransaction() 方 法 将 关闭 自动 提交 模式 ， 直 到 事务 提交 或 者 回 
滚 以 后 才 恢 复 。 


(2) 提交 事务 : 使 用 commit0 方 法 完成 事务 的 提交 操作 ， 成 功 则 返回 TRUE， 和 否则 返 
FALSE。 


(3) 事务 回 滚 : 使 用 rollBack(0 方 法 执行 事务 的 回 滚 操 作 。 
疑问 2: 如 何 通过 PDO 连接 SQL Server 数据 库 ? 


通过 PDO 可 以 实现 与 SQL Server 数据 库 连接 的 操作 。 下 面 通过 例子 来 讲解 具体 的 连接 方 
法 。 代 码 如 下 : 


可 


<?php 

header ("Content-Type:text/html;charset=utf-8"); // 设 置 页 面 的 编码 风格 
$host = 'PC-201405212233'; // 设 置 主机 名 称 
$user = 'sa'; // 设 置 用 户 名 
$pwd = '123456'; // 设 置 密码 


$dbName = 'mydatabase'7 
$dbms = 'mssql'; // 
$dsn = "mssql:host=$host;dbname-$dbName"; 
try{ 
$pdo = new PDO($dsn, $user, $pwd); 
echo "成 功 连接 SQL server 数据 库 " 
}catch (Exception $e)f{ 
Die ("错误 提示 ! ".$e->getMessage ()) 
?> 


// 设 置 需要 连接 的 数据 库 


// 利 用 try-catch 捕获 异常 


多 GH 


* RN 
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XML 作为 一 个 经 常用 来 跨 平 台 的 通用 语言 ， 越 来 越 受到 人 们 的 重视 。 XML 是 
一 种 标准 化 的 文本 格式 ， 可 以 在 Web 上 表示 结构 化 信息 ， 利 用 它 可 以 存储 有 复杂 
结构 的 数据 信息 。XML 是 HTML 的 补充 ， 但 XML 并 不 是 HTML 的 替代 品 。 在 将 
来 的 网 页 开发 中 ，XML 将 被 用 来 描述 、 存 储 数据 ， 而 HTML 则 是 用 来 格式 化 和 显 
示 数 据 的 。 本 章 主要 讲述 PHP 与 XML 技术 的 相关 应 用 。 
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17.1 认识 XML 


随 着 因特网 发 展 ， 为 了 控制 网 页 显示 样式 ， 就 增加 了 一 些 描述 如 何 显现 数据 的 标记 ， 例 
如 <center>、<b> 等 标记 。 但 随 着 HTML 的 不 断 发 展 ，W3C 组 织 意识 到 HTML 存在 一 些 无 法 
避免 的 问题 : 

e 不 能 解决 所 有 解释 数据 的 问题 ， 例 如 影音 文件 或 化 学 公式 、 音 乐 符 号 等 其 他 型 态 的 

内 容 。 

e ”效能 问题 ， 需 要 下 载 整 份 文件 ， 才 能 开始 对 文件 做 搜寻 的 动作 。 

e ”扩充 性 、 弹 性 、 易 读 性 均 不 佳 。 

为 了 解决 以 上 问题 ， 专 家 们 使 用 SGML 精简 制作 ， 并 依照 HTML 的 发 展 经 验 ， 产 生出 一 
套 使 用 上 规则 严谨 、 但 是 简单 的 描述 数据 的 语言 ， XML 。 

XML(eXtensible Markup Language， 可 扩展 标记 语言 ) 是 W3C 推荐 参考 的 通用 标记 语言 ， 
同样 也 是 SGML 的 子 类 ， 可 以 定义 自己 的 一 组 标记 。 它 具有 下 面 几 个 特点 。 

(1) XML 是 一 种 元 标记 语言 。 所 谓 “元 标记 语言 ”， 就 是 开发 者 可 以 根据 自己 的 需要 定 
义 自己 的 标记 ， 例 如 开发 者 可 以 定义 标记 <book>、<name>， 任 何 满足 XML 命名 规则 的 名 称 
都 可 以 作为 标记 ， 这 就 为 不 同 的 程序 应 用 打开 了 大 门 。 

(2) 允许 通过 使 用 自 定义 格式 ， 来 标识 、 交 换 和 处 理 数据 库 可 以 理解 的 数据 。 

(3) 基于 文本 的 格式 ， 人 允许 开发 人 员 描 述 结构 化 数据 并 在 各 种 应 用 之 间 发 送 和 交换 这 些 
数据 。 

(4) 有 助 于 在 服务 器 之 间 传输 结构 化 数据 。 

(5) XML 使 用 的 是 非 专 有 的 格式 ， 不 受 版 权 、 专 利 、 商 业 秘密 或 是 其 他 种 类 的 知识 产权 
的 限制 。XML 的 功能 是 非常 强大 的 ， 同 时 对 于 人 类 或 是 计算 机 程序 来 说 ， 都 容易 阅读 和 编 
写 。 因 而 成 为 交换 语言 的 首选 。 

网 络 带 给 人 类 的 最 大 好 处 是 信息 共享 ， 在 不 同 的 计算 机 发 送 数据 ， 而 XML 用 来 告诉 我 们 
“数据 是 什么 ”。 利 用 XML 可 以 在 网 络 上 交换 任何 一 种 信息 。 

【 例 17.1】( 示 例文 件 ch17\17.1.xmD 

<?xml Version="1.0"” encoding="GB2312" ?> 

< 电器 > 

< 家 用 电器 > 
< 品牌 > 小 天 鹅 洗衣 机 </ 品 牌 > 
< 购买 时 间 >2009-10-01</ 购 买 时 间 > 
< 价格 币 种 =" 人 民 币 ">899 元 </ 价 格 > 
</ 家 用 电器 > 
< 家 用 电器 > 
< 品牌 > 海尔 冰箱 </ 品 牌 > 
< 购买 时 间 >2011-08-16</ 购 买 时 间 > 
< 价格 币 种 =" 人 民 币 ">3990</ 价 格 > 


</ 家 用 电器 > 
</ 电 器 > 


此 处 需要 将 文件 保存 为 XML 文件 。 该 文件 中 ， 每 个 标记 是 用 汉语 编写 的 ， 是 自 定义 标 
记 。 整 个 电器 是 可 以 看 作 一 个 对 象 ， 该 对 象 包含 了 多 个 家 用 电器 ， 家 用 电器 是 用 来 存储 电器 
的 相关 信息 的 ， 也 可 以 说 ， 家 用 电器 对 象 是 一 种 数据 结构 模型 。 在 页 面 中 没有 对 那个 数据 的 
样式 进行 修饰 ， 而 只 告诉 我 们 数据 结构 是 什么 ， 数 据 是 什么 。 

在 正 9.0 中 浏览 ， 效 果 如 图 17-1 所 示 ， 可 以 看 到 ， 整 个 页 面 以 树 形 结构 显示 ， 通 过 单 击 
“-” 可 以 关闭 整个 树 形 结构 ， 而 单 击 “+” 可 以 展开 树 形 结构 。 
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<?xml version="1.0" encoding="CB2312"?> 
Lt 


电器 > 
< 品牌 > 小 天 萝 洗 衣 机 </ 品 牌 > 
一 购 二 时 间 >2009-10-01</ 购 工时 间 、 
< 们 格 币 种 =" 人 民 而 ">899 元 </ 们 格 > 
</ 家 用 电器 > 


< 家 用 电 吕 > 
< 品 必 > 到 尔 冰 稀 </ 品 让 > 
< 购买 国 间 >20141-08-16</ 购 条 时 则 > 
二 价格 币 种 =" 人 民 和 而">3990</ 痢 格 > 
</ 宁 用 电器 > 
/> 


图 17-1 XML 文件 显示 


17.2 XML 语法 基础 


XML 是 标记 语言 ， 可 支持 开发 者 为 Web 信息 设计 自己 的 标记 。XML 要 比 HTML 强大 得 
多 ， 它 不 再 是 固定 的 标记 ， 而 是 允许 定义 数量 不 限 的 标记 来 描述 文档 中 的 资料 ， 人 允许 嵌 套 的 
信息 结构 。 


17.2.1 XML 文档 的 组 成 和 声明 


一 个 完整 的 XML 文档 由 声明 、 元 素 、 注 释 、 字 符 引 用 和 处 理 指 令 组 成 。 在 文档 中 ， 所 有 
这 些 XML 文档 的 组 成 部 分 都 是 通过 元 素 标记 来 指明 的 。 可 以 将 XML 文档 分 为 三 个 部 分 ， 如 
图 17-2 所 示 。 


< 出 生日 期 >1980 2.5</ 出 生日 期 > 


< 公司 员工 > 


图 17-2 XML 文档 的 组 成 
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XML 声明 必须 作为 XML 文档 的 第 一 行 ， 前 面 不 能 有 空白 、 注 释 或 其 他 的 处 理 指令 。 完 
整 的 声明 格式 如 下 : 


<?xml] version="1.0" encoding=" 编 码 " standalone="yes/no" ?> 


其 中 version 属性 不 能 省 略 ， 且 必须 在 属性 列表 中 排 在 第 一 位 ， 指 明 所 采用 的 XML 的 版 
本 号 ， 值 为 1.0。 该 属性 用 来 保证 对 XML 未 来 版 本 的 支持 。encoding 属性 是 可 选 属性 。 该 属 
性 指定 了 文档 采用 的 编码 方式 ， 即 规定 了 采用 哪 种 字符 集 对 XML 文档 进行 字符 编码 ， 常 用 的 
编码 方式 为 UTF-8 和 GB2312。 如 果 没 有 使 用 encoding 属性 ， 那 么 该 属性 的 默认 值 是 UTF- 
8， 如 果 encoding 属性 值 设置 为 GB2312， 则 文档 必须 使 用 ANSI 编码 保存 ， 文 档 的 标记 以 及 
标记 内 容 只 可 以 使 用 ASCII 字符 和 中 文 。 

使 用 GB2312 编码 的 XML 声明 如 下 : 


<?xml version="1.0" encoding="GB2312" ?> 


XML 文档 主体 必须 有 根 元 素 。 所 有 的 XML 必须 包含 可 定义 根 元 素 的 单一 标记 对 。 所 有 
其 他 的 元 素 都 必须 处 于 这 个 根 元 素 内 部 。 所 有 的 元 素 均 可 拥有 子 元 素 。 子 元 素 必须 被 正确 地 
性 套 于 它们 的 父 元 素 内 部 。 根 标记 以 及 根 标记 内 容 共 同 构 成 XML 文档 主体 。 没 有 文档 主体 的 
XML 文档 将 不 会 被 浏览 器 或 其 他 XML 处 理 程序 所 识别 。 

注释 可 以 提高 文档 的 可 阅读 性 ， 尽 管 XML 解析 器 通常 会 忽略 文档 中 的 注释 ， 但 位 置 适当 
且 有 意义 的 注释 可 以 大 大 提高 文档 的 可 读 性 。 所 以 XML 文档 中 不 用 于 描述 数据 的 内 容 都 可 以 
包含 在 注释 中 ， 注 释 以 “<!--” 开 始 ， 以 “-->” 结 束 ， 在 起 始 符 和 结束 符 之 间 为 注释 内 容 ， 
注释 内 容 可 以 输入 符合 注释 规则 的 任何 字符 串 。 

【 例 17.2】( 示 例文 件 ch17\17.2.xmD) 


<?xml] version="1.0" encoding="gb2312"?> 
<!-- 这 是 一 个 优秀 学 生 名 单 --> 
< 学 生 名 单 > 
< 学 生 > 
< 姓名 > 张 三 </ 姓 名 > 
< 学 号 >21</ 学 号 > 
< 性 别 > 男 </ 性 别 > 
</ 学 生 > 
< 学 生 > 
< 姓名 > 李 四 </ 姓 名 > 
< 学 号 >22</ 学 号 > 
< 性 别 > 女 </ 性 别 > 
</ 学 生 > 
</ 学 生 名 单 > 


上 面 的 代码 中 ， 第 一 句 代 码 是 一 个 XML 声明 。“< 学 生 >” 标 记 是 “< 学 生 名 单 >” 标 记 
的 子 元 素 ， 而 “< 姓名 >” 标 记 和 “< 学 号 >” 标 记 是 “< 学 生 >” 的 子 元 素 。“<!--…-->” 是 一 


个 注释 。 
在 正 9.0 中 浏览 ， 效 果 如 图 17-3 所 示 ， 可 以 看 到 页 面 显示 了 一 个 树 形 结构 ， 并 且 数 据 层 
次 感 非常 好 。 
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lea] 图 HAUsershdminist 人 D7 OX| 疙 HAUsersAdministr.. x 
文件 月 ”六 缠 {E) 至 矢 (V) 次 启 实 (A) 工具 (T) 帮助 (H) 


0" encoding="GB2312"?> 


<?xml version: 
这 : 个 优秀 学 生 名 单 --> 


<!-- 这 是 一 


> 
< 姓名 > 张 三 </ 姓 名 > 
< 学 号 >21</ 字 号 > 
< 性 别 > 男 </ 性 别 > 


> 
< 姓名 > 李 四 </ 姓 名 > 
< 学 号 >22</ 学 号 > 
< 性 别 > 女 </ 性 别 > 
</ 学 生 > 


</ 学 生 名 单 > 


17-3 XML 在 页 面 中 的 树 形 结构 


17.2.2 ”操作 XML 元 素 


元 素 是 以 树 形 分 层 结构 排列 的 ， 它 可 以 嵌 套 在 其 他 元 素 中 。 

1， 元 素 类 别 

在 XML 文档 中 ， 元 素 也 分 为 非 空 元素 和 空 元 素 两 种 类 型 。 一 个 XML 非 空 元 素 是 由 开始 
标记 、 结 束 标记 以 及 标记 之 间 的 数据 构成 的 。 开 始 标记 和 结束 标记 用 来 描述 标记 之 间 的 数 
据 。 标 记 之 间 的 数据 被 认为 是 元 素 的 值 。 非 空 元 素 的 语法 结构 如 下 所 示 : 

< 开始 标记 > 文本 内 容 </ 结 束 标记 > 

而 空 元 素 就 是 不 包含 任何 内 容 的 元 素 ， 即 开始 标记 和 结束 标记 之 间 没 有 任何 内 容 的 元 
素 。 其 语法 结构 如 下 所 示 : 

< 开始 标记 ></ 结 束 标 记 > 

可 以 把 元 素 内 容 为 文本 的 非 空 元 素 转换 为 空 元 素 。 例 如 : 

<hello> 下 午 好 </hello> 

这 里 <hello> 是 一 个 非 空 元 素 ， 如 果 把 非 空 元 素 的 文本 内 容 转 换 为 空 元 素 的 属性 ， 那 么 转 
换 后 的 空 元 素 可 以 写 为 : 


<hello content=" 下 午 好 "></hello> 


2. 元 素 命名 规范 


XML 元 素 命名 规则 与 Java、C 等 的 命名 规则 类 似 ， 它 也 是 一 种 对 大 小 写 敏感 的 语言 。 
XML 元 素 命名 必须 遵守 下 列 规则 : 
@ ”元 素 名 中 可 以 包含 字母 、 数 字 和 其 他 字符 。 如 <place>、< 地 点 >、<no123> 等 。 元 素 
名 中 虽然 可 以 包含 中 文 ， 但 是 在 不 支持 中 文 的 环境 中 将 不 能 够 解释 包含 中 文字 符 的 
XML 文档 。 
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@ ”元 素 名 中 不 能 以 数字 或 标点 符号 开头 。 例 如 <123no>、<.name>、<?error> 元 素 名 称 都 


是 非法 名 称 。 
@ ”元 素 名 中 不 能 包含 空格 。 如 不 能 是 <no 123>。 
3. 元 素 谋 套 


元 素 的 内 容 可 以 包含 子 元 素 。 子 元 素 本 身 也 是 元 素 ， 被 嵌 套 在 上 层 元 素 之 内 。 如 果子 元 
素 嵌 套 了 其 他 元 素 ， 那 么 它 同时 也 是 父 元 素 ， 例 如 下 面 所 示 的 部 分 代码 : 


<?xml version="1.0" encoding="gb2312" ?> 
<students> 
<student> 
<name> 张 三 </name> 
<age>20</age> 
</student> 


</students> 


<student> 是 <students> 的 子 元 素 ， 同 时 也 是 <name> 和 <age> 的 父 元 素 ， 而 <name> 和 <age> 
是 <student> 的 子 元 素 。 


4. 元 素 示例 
【 例 17.3】( 示 例文 件 ch17\17.3.xml) 


<?xml] version="1.0" encoding="gb2312" ?> 
< 通信 录 > 
<!--" 记 录 " 标 记 中 包含 姓名 、 地 址 、 电 话 和 电子 邮件 --> 
< 记录 date="2011/2/1"> 
< 姓名 > 张 三 </ 姓 名 > 
< 地 址 > 中 州 大 道 1 号 </ 地 址 > 
< 电话 >0371-12345678</ 电 话 > 
< 电子 邮件 >rose@tom.com</ 电 子 邮 件 > 
</ 记 录 > 
< 记录 date="2011/3/12"> 
< 姓名 > 李 四 </ 姓 名 > 
< 地 址 > 邯郸 市 工农 大 道 2 号 </ 地 址 > 
< 电话 >123456</ 电 话 > 
</ 记 录 > 
< 记录 date="2011/6/23"> 
< 姓名 > 闫 阳 </ 姓 名 > 
< 地 址 > 长 春 市 幸福 路 6 号 </ 地 址 > 
< 电话 >0431-123456</ 电 话 > 
< 电子 邮件 >yy@sina .com</ 电 子 邮 件 > 
</ 记 录 > 
</ 通 信 录 > 


文件 代码 中 ， 第 一 行 是 XML 声明 ， 它 声明 该 文档 是 XML 文档 、 文 档 所 遵守 的 版 本 号 以 
及 文档 使 用 的 字符 编码 集 。 
这 个 例子 中 ， 遵 守 的 是 XML 1.0 版 本 规范 ， 字 符 编码 是 gb2312 编码 方式 。< 记 录 > 是 < 通 
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信和 录 > 的 子 标记 ， 但 < 记录 > 标记 同时 是 < 姓名 > 和 < 地 址 > 等 标记 的 父 元 素 。 
在 正 9.0 中 浏览 ， 效 果 如 图 17-4 所 示 ， 可 以 看 到 ， 页 面 显 示 了 一 个 树 形 结构 ， 每 个 标记 
中 间 包 含 相应 的 数据 。 


半 HAuserswdminisrator PD ~ © X | 车 Huserswdminisrator x | | 
EEC ETETOE7TEOECTIT 


<?xml version="1.0" encoding="GB2312"?> 
~ < 通讯 录 > 
< 名 、 地 址 电话 和 电子 邮件 --> 


< 记录 1°> 
< 姓名 > 张 三 </ 姓 名 > 
< 地 址 > 中 州 大 道 1 号 </ 地 址 > 
< 电话 >0371-12345678</ 电 话 > 
< 电子 邮件 >rose@tom.com</ 电 子 邮 件 > 
</ 记 录 > 
- < 记录 date="2011/3/12"> 旧 
< 姓名 > 李 四 </ 姓 名 > 
3 本 > 部 革 宙 家 大通 2 号 </ 地 址 > 
06 
/记录 


- < 记录 date=" fa s 
< 姓名 > 同 阳 </ 姓 名 
< 地址 > 长 春 市 检视 6 号 </ 地 址 > 
< 电话 >0431-123456</ 所 话 > 
ye -Com</ 电 子 邮件 > 


17-4 ”元素 示例 
17.2.3 (处 理 指令 ) 实 体 引用 


有 些 字符 在 XML 中 有 特殊 的 意思 。 而 这 些 字符 需要 转 义 。 

比如 在 <name></name> 之 间 无 法 直接 使 用 用 于 编写 标签 的 符号 “<” 和 “>”。 如 果 直 接 
在 标签 内 使 用 ， 如 <name> 天 地 一 斗 < 天 地 二 斗 <name>， 在 XML 执行 时 便 会 出 错 。 因 为 
XML 不 知道 标签 的 结尾 从 哪里 开始 。 

要 解决 这 个 问题 ， 只 有 用 另外 的 一 种 方式 来 表示 此 符号 ， 使 所 有 符号 在 XML 中 合法 ， 这 
样 就 不 会 使 XML 发 生字 符 确认 的 混 浠 了。 这 种 表示 方法 就 是 “实体 引用 ”。 

一 些 实体 引用 如 下 : “<” 为 “&lt;”，“>” 为 “&gt;”，“&” 为 “&amp;”，“”” 为 
“&apos;”，“”” 为 “&qout;:”。 所 以 : 

<name> 天 地 一 斗 < 天 地 二 斗 </name> 

可 以 表示 为 : 

<name> 天 地 一 斗 &lt; 天 地 二 斗 </name> 


XML 对 空格 符 不 做 多 余 处 理 ， 保 留 输入 的 情况 。 
17.2.4 使 用 XML 命名 空间 
XML 内 的 元 素 名 称 都 是 通过 自 定义 产生 的 。 所 以 只 有 遵循 一 定 的 规则 才 不 会 出 现 问题 。 


XML 命名 空间 就 给 出 了 避免 命名 冲突 的 方法 。 
例如 ， 如 果 一 个 XML 文档 中 出 现 了 HTML 文档 中 才 出 现 的 元 素 名 称 ， 如 下 : 


a 


水 淋 JWNX Jr dHd 二 并 二 


IGG 


309 S 


PHP+MySQL 动 态 网 站 开发 


2e Mm A 
案例 课堂 »… 
<body> 
<form></form> 
</body> 


则 浏览 器 在 解析 的 时 候 将 会 出 错 ， 不 知道 到 底 是 按照 XML 进行 还 是 按照 HTML 进行 。 
要 解决 这 个 问题 ， 可 以 通过 使 用 名 称 前 级 。 例 如 : 


<s:body> 
<s:form></s:form> 
</s:body> 


其 中 ，“s:” 就 是 元 素 名 前 级 。 但 是 配合 名 称 前 缀 的 使 用 ， 一 定 要 在 “ 根 元 素 ” 上 定义 命 
名 空间 (namespace) 属 性 。 例 如 : 


<?xml Version="1.0"” encoding="gb2312"?> 
<store xmlns:s="http://www.w3.0rg/TR/html14/"> 
<album catalog="song"> 
<name> 天 地 一 斗 </name> 
<author>Jay</author> 
<heading> 周 杰 伦 专辑 </heading> 
<body> 这 是 jay 的 最 新 专辑 </body> 
<time>2011-02-20</time> 
</album> 
</store> 


其 中 ，xmlns 属性 的 格式 是 : 


xmlns :前 缀 名 ="URI" 


其 中 “URI” 是 指向 介绍 前 级 信息 的 页 面 ， 不 是 靠 这 个 来 解析 前 级 名 。 
例如 : 


<?xml] version="1.0" encoding="gb2312"?> 
<store xmlns="http://www.w3.org/TR/htm14/"> 
<album catalog="song"> 
<name> 天 地 一 斗 </name> 
<author>Jay</author> 
<head> 周 杰 伦 专辑 </head> 
<body> 这 是 jay 的 最 新 专辑 </body> 
<time>2011-02-20</time> 
</album> 
</store> 


上 述 代码 中 定义 了 一 个 默认 的 命名 空间 ， 也 就 是 在 不 加 任何 前 缀 的 情况 下 ， 出 现 的 
HTML 元 素 就 按照 HTML 元 素 进行 处 理 。 

例如 其 中 的 : 

<head> 周 杰 伦 专辑 </head> 

<body> 这 是 jay 的 最 新 专辑 </body> 


将 按照 HTML 元 素 进行 处 理 。 
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17.2.5 XMLDTD 


XML 一 定 要 按照 规定 的 语法 形式 书写 。 为 了 验证 它 的 合法 性 ， 可 以 通过 DTD 文档 进行 
验证 。 

DTD 是 Document Type Definition 的 缩写 ， 意 思 是 文档 类 型 定义 。DTD 文档 是 对 类 型 文 
档 进行 定义 的 。 在 XML 中 使 用 ， 就 是 用 来 对 XML 文档 进行 定义 的 。 

例如 DTD 文件 store.dtd: 


<!DOCTYPE store 

[ 

<!IELEMENT store (album) > 

<!ELEMENT album (name,author,heading,body,time)> 
<!ELEMENT author (#PCDRTRA) > 

<!ELEMENT heading (#PCDRTR) > 

<!ELEMENT body (#PCDRTR) > 

<!ELEMENT 七 ime (#PCDRTR) > 

i 


就 定义 了 store.xml 文件 的 架构 。 
如 果 要 使 DTD 起 作用 ， 可 以 进行 相关 的 添加 ， 引 入 文件 : 
<?xml Version="1.0"” encoding="gb2312"?> 


<!DOCTYPE store SYSTEM "store.dtd"> 
<store> 
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<album catalog="song"> 
</album> 
</store> 


也 可 以 直接 把 它 写 在 XML 的 声明 语句 之 后 ， 例 如 以 下 代码 : 


<?xml] version="1.0" encoding="gb2312"?> 
<!DOCTYPE store 

[ 

<!IELEMENT store (album) > 

<!ELEMENT album (name,author,heading,body,time)> 
<!IELEMENT name (#PCDATA)> 

<!ELEMENT author (#PCDATA)> 

<!IELEMENT heading (#PCDATA)> 

<!IELEMENT body (#PCDATA)> 

<!IELEMENT 七 ime (#PCDATA)> 

I 


<store> 
<album catalog="song"> 
</album> 

</store> 
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17.2.6 ”使 用 CDATA 标记 


上 例 中 <!ELEMENT name(#PCDATA)> 中 的 “PCDATA” 指 的 是 Parsed Character Data， 
即 是 使 用 XML 解析 器 对 字符 数据 进行 解析 。 

“CDATA” 指 的 是 Character Data， 即 是 “不 ”使 用 解析 器 对 字符 数据 进行 解析 。 

在 很 多 表示 语言 的 头 部 ， 会 出 现 以 <script></script> 开 头 ， 里 面包 含 <![CDATA[]]> 标 记 的 
代码 ， 例 如 : 


<script type="text/javascript"> 
<! [CDRTRT[ 
function upperCase() { 
Var x = document .getElementById ("name") .value 
document .getElementById("name") .value = x.toUpperCase() 
3 
]]> 
</script> 


其 中 ，“<![CDATA[]]>” 标 记 意 味 着 包含 在 此 标记 里 面 的 代码 不 被 当前 文档 解析 器 解 


析 。 如 果 是 在 HTML 中 使 用 ， 则 不 被 HTML 解析 器 解析 。 如 果 在 XML 中 使 用 ， 则 不 被 
XML 解析 器 解析 。 


标记 内 部 的 代码 不 能 包含 标记 符 本 身 。 


17.3 ”把 XML 文档 转换 为 HTML 加 以 输出 


根据 上 一 节 对 XML 的 介绍 ， 可 以 得 出 以 下 结论 。 
(1) XML 是 用 来 传输 和 储存 数据 的 ， 是 W3C 的 推荐 产物 。 
(2) XML 是 一 种 标识 语言 ， 是 需要 使 用 标签 (Tag) 来 表明 语言 元 素 的 。 如 同 HTML 一 类 
的 标识 语言 。 但 是 HTML 是 用 来 展示 数据 的 。 
(3) XML 的 标签 不 像 HTML 那样 有 固定 标准 ， 用 户 使 用 XML 需要 自己 定义 标签 。 
(4) XML 语言 本 身 并 不 做 什么 事情 ， 它 只 是 按照 一 定 的 方式 把 数据 组 织 在 一 起 。 
例如 以 下 代码 : 
<?xml version="1.0" encoding="gb2312"?> 
<album> 
<name> 天 地 一 斗 </name> 
<author>Jay</author> 
<heading> 周 杰 伦 专辑 </heading> 
<body> 这 是 jay 的 最 新 专辑 </body> 


<time>2014-02-20</time> 
</album> 


这 个 XML 文件 包含 了 专辑 的 名 称 、 作 者 、 标 头 、 主 体内 容 和 发 布 时 间 ， 而 且 它们 所 有 的 
标签 都 是 自 定 义 的 ， 所 以 浏览 器 无 法 识别 这 些 ， 不 会 进行 泻 染 展示 。 那 么 如 何 使 XML 中 所 携 
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带 的 数据 展示 出 来 呢 ? 

用 户 可 以 使 用 传统 的 CSS 和 JavaScript 来 实现 ， 但 是 最 好 的 方法 是 使 用 XSLT。 

XSLT 是 用 来 把 XML 文档 转换 为 HTML 文档 的 语言 ， 是 Extensible Stylesheet Language 
Transformations 的 缩写 ， 意 思 是 扩展 样式 转换 。XSLT 相当 于 XML 的 HTML 模板 。 
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17.4 在 PHP 中 创建 XML 文档 


XML 语言 是 标识 语言 。PHP 是 脚本 语言 。 使 用 脚本 语言 是 可 以 创建 标识 语言 的 。 
ED 在 网 站 下 建立 xmlphp 文件 ， 输 入 代码 如 下 : 


<?php 

header ("Content-type: text/xml"); 
echo "<?xml version=\"1.0\" encoding=\"gb2312\"?>"; 
echo "<store>"; 

echo "<album catalog=\"song\">"; 
echo "<name> 天 地 一 斗 </name>"; 

echo "<author>Jay</author>"; 

echo "<heading> 周 杰 伦 专辑 </heading>"; 
echo "<body> 这 是 jay 的 最 新 专辑 </body>"; 
echo "</album>"; 

echo "</store>"; 

Cs 


EUP9 运行 xml.php， 结 果 如 图 17-5 所 示 。 
pnp 
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<?xml version="1.0" encoding="GB2312"?> 


- <album catalog="song"> 
<name> 天 地 一 斗 </name> 
<author>Jay</author> 
<heading> 周 杰 伦 专辑 </heading> 
<body> 这 是 jay 的 最 新 专 括 </body> 

</album> 
</store> 
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17-5 ”xml.php 程序 的 运行 结果 
案例 分 析 : 


(1) 在 xml.php 中 通过 header(“Content-type: text/xml”): 定 义 输出 文本 类 型 。 
(2) PHP 通过 echo 命令 直接 把 XML 元 素 通过 字符 串 输出 。 
17.5 使 用 SimpleXML 扩展 


以 上 通过 PHP 创建 XML 文档 采取 了 静态 方法 。 如 果 想 要 从 获得 的 数据 中 动态 地 创建 或 
者 读 取 XML 文件 ， 应 该 用 什么 方式 呢 ? 最 简单 的 就 是 使 用 PHP 中 提供 的 SimpleXML 扩展 。 
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17.5.1 创建 SmpleXMLElement 对 象 


从 PHP 5 版 本 开始 ，PHP 中 才 有 SimpleXML 扩展 。SimpleXML 是 一 个 XML 解析 器 ， 它 
能 够 轻松 读 取 XML 文档 ， 也 是 一 个 XML 控制 器 ， 能 够 轻松 创建 XML 文档 。 

SimpleXML 的 好 处 就 是 把 PHP 对 XML 的 处 理 变 得 “simple ”简单 化 。 不 需要 使 用 传统 
的 SAX 扩 展 和 DOM 扩展 来 为 每 个 XML 文档 编写 解析 器 。 

SimpleXML 扩展 拥有 一 个 类 、 三 个 函数 和 众多 的 类 方法 。 下 面 就 来 介绍 SimpleXML 扩 
展 的 对 象 SimpleXMLElement。 

使 用 SimpleXMLElement 对 象 创建 一 个 XML 文档 时 ， 首 先 要 创建 一 个 对 象 。 使 用 
SimpleXMLElementO 函 数 创建 此 对 象 。 

下 面 通过 案例 介绍 此 过 程 ， 具 体 步骤 如 下 。 

在 网 站 下 建立 simplexml.php 文件 ， 输 入 代码 如 下 : 


<?php 
$xmldoc = 
"<?xml version=\"1.0\" encoding=\"gb2312\"?> 
<store> 
<album catalog=\"song\"> 
<name> 天 地 一 斗 </name> 
<author>Jay</author> 
<heading> 周 杰 伦 专辑 </heading> 
<body> 这 是 jay 的 最 新 专辑 </body> 
<time>2011-02-20</time> 
</album> 
</store>"; 
$simplexmlobj = new SimpleXMLElement ($xmldoc); 
echo $simplexmlobj->asxXML(); 
Ee 


运行 simplexml.php， 结 果 如 图 17-6 所 示 。 


【< Er BD- BCx|@localhost x es 


ETC) 
天 地 一 斗 Jay 周杰伦 专辑 这 是 jay 的 最 新 专辑 2011-02-20 


17-6 ”simplexml.php 的 运行 结果 
案例 分 析 : 
(1) $xmldoc 为 一 个 字符 串 变 量 ， 里 面 是 一 个 完整 的 XML 文档 。 
(2) $simplexmlobj 为 SimpleXMLElementO 函 数 通过 new 关键 字 把 包含 XML 文档 的 字符 
串 变 量 $xmldoc 生成 的 SimpleXML 对 象 。 
(3) 对 象 $simplexmlobj 通过 类 方法 asXMLO 输 出 XML 文档 。 输 出 结果 如 图 17-6 所 示 ， 


二 
G1 


攻 训 


为 一 个 字符 串 。 由 于 没有 参数 设置 ， 所 以 XML 文档 的 数据 输出 为 字符 串 。 
继续 上 面 的 示例 ， 修 改 samplexmlphp 文件 中 的 : 


echo $simplexmlobj->asXML(); 

为 : 

echo $simplexmlobj->asXML("storesim.xm]l"); 

其 中 ， 给 类 方法 asXMLO 添 加 的 参数 为 一 个 XML 文件 名 storesim xml。 


继续 运行 simplexmlLphp， 则 在 该 网 页 的 同 目录 下 得 到 storesim.xml 文件 ， 打 开 文 件 后 ， 
其 中 的 代码 如 下 : 


<?xml Version="1.0"” encoding="gb2312"?> 
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<store> 
<album catalog="song"> 
<name> 天 地 一 斗 </name> 
<author>Jay</author> 
<heading> 周 杰 伦 专辑 </heading> 
<body> 这 是 jay 的 最 新 专辑 </body> 
<time>2011-02-20</time> 
</album> 
</store> 


17.5.2 ”访问 特定 节点 元 素 和 属性 


使 用 XML 数据 很 重要 的 就 是 访问 需要 访问 的 数据 。SimpleXML 可 以 通过 simplexml_ 
load_file() 函 数 很 方便 地 完成 此 任务 。 

此 例 介 绍 加 载 XML 文件 并 访问 数据 的 过 程 ， 具 体 步骤 如 下 。 

ED 在 网 站 下 建立 文件 storeutfs xml， 输 入 代码 如 下 : 


<?xXml Version="1.0"” encoding="utf-8"?> 
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<store> 
<album catalog="song"> 
<name>help</name> 
<author>beatles</author> 
<heading>farmers</heading> 
<body>this is published in 1965.</body> 
<time>2011-02-20</time> 
</album> 
</store> 


在 网 站 下 建立 文件 simplexmlele.php， 输 入 代码 如 下 : 


<?php 

$storeobj = simplexml load file("storeutf8.xml"); 
echo $storeobj->album->name ."<br />"; 

print r($storeobj); 
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运行 simplexmlele.php， 结 果 如 图 17-7 所 示 。 
总 pifoc- 年 -CX| 生 localbost 


文件 (F) 奖 强 [E) 吾 看 V) 要 太夫 工具 0) 大 D(H 


help 
SimpleXMLElement Object ( [album] => SimpleXMLElement Object 
( [Gattributes] => Array ( [catalog] => song ) [name] => 


help [author] => beatles [heading] => famers [body] => this 
is published in 1965. [time] => 2011-02-20 ) ) 


图 17-7 simplexmlele.php 的 运行 结果 


案例 分 析 : 

(1) storeutf8.xml 为 一 个 XML 文档 。 不 过 它 的 字符 编码 为 utf-8。 

(2) simplexml load file0 函 数 加 载 XML 文件 ， 并 且 生 成 一 个 对 象 ， 赋 值 给 $storeobj 变 
量 。simplexml load file0 函 数 把 加 载 文件 的 数据 都 自动 转换 为 utf8 的 编码 格式 。 若 文字 编码 
为 其 他 格式 ， 则 要 采用 其 他 加 载 方式 。 

(3) $storeobj 对 象 通过 属性 访问 XML 文档 数据 。 使 用 $storeobj->album->name 就 输出 了 
XML 文档 中 的 <name>help</name> 元 素 和 数据 。 

(4) 通过 print_r0 输 出 $storeobj 对 象 的 所 有 数据 和 属性 。 


17.5.3 添加 XML 元 素 和 属性 


通过 simplexml 类 的 addAttribute 和 addChild 方法 添加 XML 元 素 和 属性 。 步 又 如 下 。 
ED 在 网 站 下 建立 simplexmlele2.php 文件 ， 输 入 代码 如 下 : 


<?php 

$storeobj = simplexml load file("storeutf8.xml") ; 
$storeobj->addAttribute ("storetype", "CDshop"); 
$storeobj->album->addchild("type", "CD"); 

echo $storeobj->album->name."<br />"; 
$storeobj->asxXML ("storeutf8-2.xml"); 

Ea 


运行 simplexmlele2.php， 结 果 如 图 17-8 所 示 。 
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17-8 ”simplexmlele2.php 的 运行 结果 


全 
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此 时 在 simplexmlele2.php 文件 的 同 目录 下 得 到 storeutf8-2.xml 文件 。 打 开 文件 ， 
其 中 的 代码 如 下 : 


<?xml Version="1.0"” encoding="utf-8"?> 
<store storetype="CDshop"> 
<album catalog="song"> 
<name>help</name> 
<author>beatles</author> 
<heading>famers</heading> 
<body>this is published in 1965.</body> 
<time>2011-02-20</time> 
<type>cD</type> 
</album> 
</store> 


案例 分 析 : 

(1) simplexml load_file0 加 载 storeutf8.xml。 通 过 类 方法 addAttribute0 向 根 元 素 $storeobj 
添加 storetyp 属性 ， 其 值 为 CDshop 。 

(2) $storeobj->album->addChild(“type”,“CD”); 语 句 向 $storeobj->album 元 素 内 添加 子 元 素 
type， 其 值 为 CD。 

(3) $storeobj->asXML(“storeutf8-2.xml”); 语 句 生成 storeutf8-2.xml 文件 。 
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17.6 动态 创建 XML 文档 


使 用 SimpleXML 对 象 可 以 十 分 方便 地 读 取 和 修改 XML 文档 ， 但 是 却 无 法 动态 地 建立 
XML。 如 果 想 动态 地 创建 XML 文档 ， 需 要 使 用 DOM 来 实现 。DOM 是 Document Object 
Model 的 简称 ， 意 思 是 文件 对 象 模型 ， 它 是 W3C 组 织 推荐 的 处 理 可 扩展 标志 语言 的 标准 编程 
接口 。 

下 面 通过 示例 来 讲解 使 用 DOM 动态 创建 XML 文档 的 方法 。 

在 网 站 下 建立 dtxml.php 文件 ， 代 码 如 下 : 


<?php 


$dom = new DomDocument ('1.0','gb2312'); // 创 建 DoM 对 象 

$store = $dom->createElement ('store'); / /创建 根 节点 store 
$dom->appendChild ($store); // 将 创建 的 根 节点 添加 到 DoM 对 象 中 
$album = $dom->createElement ('album'); // 创 建 节点 album 

$store ->appendchild ($album); // 将 节点 album 追加 到 DoM 对 象 中 
$musiccd = $dom->createElement ('musiccd'); / /创建 节点 musiccd 

$album ->appendchild ($musiccd); // 将 musiccad 追加 到 DoM 对 象 中 
$type = $dom->createAttribute('type'); / /创建 节 点 属性 type 
$computerbook->appendchild ($type); // 将 属性 追加 到 musicca 元 素 后 
$type_value = $dom->createTextNode ('music'); // 创 建 一 个 属性 值 
$type->appendchild ($type value); // 将 属性 值 赋 给 type 

$name = $dom->createElement ('name'); / /创建 节 点 name 

Smusiccd ->appendChild ($name); // 将 节点 追加 到 DoM 对 象 中 
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$name value = $dom->createTextNode (iconv('gb2312', "utf-8'"，' 周 杰 伦 专辑 ') ) ; 


// 创 建 元 素 值 
$name->appendChild ($name value); // 将 值 赋 给 节点 name 
echo $dom->saveXML(); // 输 出 XML 文件 


?> 


运行 后 ， 结 果 如 图 17-9 所 示 。 


本 mapyyoc- 国内- ECX| 达 omihos x me 
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<?xml version="1,0" encoding="GB2312"?> 

- <store> 

- <album> 

-<musiccd type="music'> 
<name> 周 杰 伦 专辑 </name> 
</musiccd> 

</album> 

</store> 
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图 17-9 dtxml.php 文件 的 运行 结果 


17.7 疑难 解 惑 


疑问 1: XML 和 HTML 文件 有 什么 相同 点 和 不 同 点 ? 

HTML 和 XML 都 是 从 SGML 发 展 而 来 的 标记 语言 ， 因 此 ， 它 们 有 些 共 同 点 ， 如 相似 的 
语法 和 标记 。 不 过 HTML 是 在 SGML 定义 下 的 一 个 描述 性 语言 ， 只 是 一 个 SGML 的 应 用 。 
而 XML 是 SGML 的 一 个 简化 版 本 ， 是 SGML 的 一 个 子 集 。 

XML 是 用 来 存放 数据 的 ，XML 不 是 HTML 的 替代 品 ，XML 和 HTML 是 两 种 不 同 用 途 
的 语言 。XML 是 被 设计 用 来 描述 数据 的 。HTML 只 是 一 个 显示 数据 的 标记 语言 。 


疑问 2: 在 向 XML 添加 数据 时 出 现 乱 码 现象 怎么 办 ? 


iconv0 函 数 是 转换 编码 函数 。 在 向 页 面 或 文件 写 入 数据 时 ， 如 果 添加 的 数据 的 编码 格式 
与 文件 原 有 的 编码 格式 不 符 ， 会 出 现 乱 码 的 问题 。 解 决 的 方法 是 : 使 用 iconv0 函 数 将 数据 从 
输入 时 所 使 用 的 编码 转换 为 另 一 种 编码 格式 后 再 输出 ， 即 可 解决 上 面 的 问题 。 


SQL 的 结合 是 开发 Web 网 站 的 黄金 搭档 。 本 章 将 以 论坛 网 站 的 开发 


PHP 与 M 
为 例 进行 讲解 。 论 坛 网 站 的 开发 具有 网 站 开发 的 代表 性 ， 通 过 对 本 章 的 学 习 ， 读 者 
可 以 掌握 PHP + MySQL 开发 网 站 的 常用 知识 和 技巧 。 
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18.1 网 站 的 需求 分 析 
在 开发 网 站 之 前 ， 首 先 应 分 析 网 站 的 需要 ， 包 括 网 站 需求 分 析 和 网 站 的 功能 模块 分 析 。 
18.1.1 需求 分 析 


需求 分 析 是 论坛 网 站 开发 的 必要 环节 ， 本 网 站 的 需求 如 下 。 

(1) 论坛 的 游客 可 以 注册 、 登 录 网 站 和 浏览 主题 。 

(2) 论坛 的 普通 注册 用 户 拥有 浏览 、 发 表 主 题 、 回 复 主题 、 修 改 自己 的 个 人 资料 、 查 询 
主题 、 修 改 自己 发 布 或 回复 的 帖子 等 功能 。 

(3) 版 主 对 版 块 的 管理 功能 : 包括 对 帖子 的 操作 ， 如 查询 主题 、 置 项 、 加 精 、 移 动 、 编 
辑 和 删除 ， 对 用 户 的 操作 为 禁止 发 言 和 删除 id; 对 版 块 的 操作 主要 包括 发 布 版 块 和 广告 。 

(4) 系统 管理 员 对 版 块 的 操作 为 建立 、 修 改 和 删除 版 块 ; 对 用 户 的 操作 为 禁止 发 言 和 删 
除 id; 对 帖子 的 主要 操作 为 查询 主题 、 置 项 、 加 精 、 移 动 、 编 辑 和 删除 ， 对 论坛 的 操作 为 开 
放 或 关闭 会 员 注 册 功 能 。 


18.1.2 ”网 站 功能 模块 分 析 


网 站 主要 有 下 列 功能 模块 。 

(1) 会 员 注册 模块 : 新 会 员 注册 、 提 供 会 员 信息 、 检 验 会 员 信 息 的 有 效 性 并 将 会 员 信息 
持久 化 。 

(2) 会 员 登 录 模 块 : 提供 用 户 凭证 、 验 证 用 户 信息 、 基 于 角色 授权 。 

(3) 会 员 管理 模块 : 管理 员 由 系统 初始 化 分 配 一 个 ， 管 理 员 可 以 对 会 员 信息 进行 部 分 更 
改 ， 主 要 包括 色彩 调整 、 版 主 调整 、 删 除 会 员 等 。 

(4) 论坛 版 块 管理 模块 : 管理 员 可 以 添加 、 删 除 、 调 整 、 置 项 、 隐 藏 论坛 版 块 。 

(5) 帖子 管理 模块 : 管理 员 可 以 对 所 有 帖子 进行 转移 、 置 项 、 删 除 等 操作 ， 版 主 可 以 将 
版 块 帖 子 置顶 、 删 除 等 。 

(6) 帖子 发 表 模块 : 用 户 可 以 在 其 权限 允许 的 版 块 内 发 表 帖子 。 

(7) 帖子 回复 模块 : 用 户 可 以 对 其 权限 允许 的 主题 发 表 回复 。 

(8) 帖子 浏览 模块 : 用 户 可 以 浏览 所 有 可 见 的 帖子 。 

(9) 帖子 检索 模块 : 注册 用 户 可 以 提供 标题 关键 字 ， 检 索 所 有 可 见 的 主题 帖 ， 并 可 以 查 
看 自己 发 表 或 回复 的 帖子 。 


18.2 ”数据库 分 析 


分 析 完 网 站 的 功能 后 ， 开 始 分 析 数 据 库 的 逻辑 结构 并 建立 数据 表 。 


可 


18.2.1 分 析 数 据 库 
本 论坛 的 数据 库 名 称 为 bbs_data， 共 有 5 个 数据 表 ， 各 数据 表 之 间 的 逻辑 关系 如 图 18-1 


所 示 。 
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son_Imodule info user_info 


图 18-1 ”数据 表 的 逻辑 关系 
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18.2.2 ”创建 数据 表 


分 析 数 据 库 的 结构 后 ， 即 可 创造 数据 表 ， 各 个 数据 表 如 表 18.1~18.5 所 示 。 
表 18.1 manage_user_info( 管 理 用 户 信息 数据 表 ) 


字段 名 类 型 字段 意义 备 注 
id int 序号 


管理 用 户 间 录 名 
管理 用 户 密码 


表 18.2 user_info( 用 户 信息 数据 表 ) 


编 号 类 型 字段 意义 备 注 
1 i [| imt 序号 

2 user name char(16) 用 户 登 录 名 
3 用 户 窗 码 
4 注册 时 间 


5 | ae 最 后 登录 hj 
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编 备 注 

1 id int 

2 module name char(66) 

3 show_order 

编 字段 意义 备注 

1 id int 序号 

有 father module id int 隶属 的 大 板块 的 id 同 father module info 中 的 id 
3 module name char(66) 子 板块 名 称 

4 module cont text 子 板块 简介 

5 同 user_info 中 的 user_ name 


表 18.5 note_info( 发 帖 信息 数据 表 ) 


编号 | 字段 名 类 型 备 注 

1! ua int [ENE 

module id int 同 son_ module info 中 id 

3 up id int 同 本 表 中 的 id 

4 title char(88) 

5 cont text 

6 time datetime 发 帖 时 间 

7 User_name char(16) 同 user_info 中 的 user_name 
8 times int 浏览 次 数 


18.3 ”论坛 的 代码 实现 


下 面 来 分 析 论 坛 的 代码 是 如 何 实现 的 。 
18.3.1 数据 库 连 接 相关 文件 


主要 的 数据 库 连 接 相 关 文 件 如 下 。 
文件 mysqlinc 位 于 随 书 光盘 的 chlg\inc\ 下 ， 用 于 自 编 连接 数据 库 、 服 务 器 、SQL 语句 的 
执行 函数 。 主 要 代码 如 下 : 


加 


<?php 
class mysql{ // 连 接 服务 器 、 数 据 库 以 及 执行 SQL 语句 的 类 库 
public $database; 
public $server username; 
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public $server userpassword; 
function mysql() { // 构 造 函 数 初始 化 所 要 连接 的 数据 库 
$this->server username="root"; 
$this->server userpassword=""; 
} //end mysql() 
function link($database) { // 连 接 服务 器 和 数据 库 
// 设 置 所 有 连接 的 数据 库 
if ($database==""){ 
$this->database="bbs data"; 
}elsef{ 
$this->database=$database; 


} 
// 连 接 服务 器 和 数据 库 
if(@$id=mysql connect('localhost', $this->server username, 
$this->server userpassword)){ 
if(!mysql select db($this->database, $id)){ 
echo "数据 库 连接 错误 ! ! ! "7 
exit; 
3 
jelsei{ 
echo "服务 器 正在 维护 中 ， 请 稍 后 重 试 ! ! ! "; 


exit; 
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} 
}//end link($database) 
function excul($query){ // 执 行 sor 语句 
if($result=mysql query ($query)){ 
return $result; 


}else{ 
echo "SQL 语句 执行 错误 ! ! ! 请 重 试 !!!"; 
exit; 

} 


} //end exec($query) 
} //end class mysql 
?> 


文件 myfunction.inc 位 于 随 书 光盘 的 chl8\inc\ 下 ， 用 于 自 编 函 数 库 。 主 要 代码 如 下 : 


<?php 

class myfunction{ 

/111111111111111/ 字 符 转 换 : 向 数据 库 中 插入 或 更 新 时 用 /771111111111111111111111/ 
function str tol($str) 


{ 
$str=str replace(" ", "gnbsp;",$str); // 把 空格 蔡 换 为 HTML 的 字符 串 空格 


$str=str replace ("<","&lt;",$str); // 把 HTML 的 输出 标志 正常 输出 
$str=str replace (">", "ggt;",$str); // 把 HTML 的 输出 标志 正常 输出 
$str=nl2br ($str); // 把 回 车 蔡 换 成 HTML 中 的 br 
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return $str; 


/11111111111111111111/ 由 子 板块 的 id 返回 该 子 板块 的 主题 数 /1711111111111111111111/ 


function son module idtonote num($son module id){ 


} 


$aa=new mysql; 

$aa->link(""); 

$query="select * from note info where module id='" 
.$son module id."' and up id="'0'"; 

$rst=$aa->excu ($query); 

return mysql num rows($rst); 


POA EAN RAO OA NRO EN EN do do 
A11111111111111111111/ 由 子 板块 的 ia 返回 该 子 板块 的 帖子 数 /1777711111111111111111 


function son module idtonote num?2($son module iqd){ 


} 


$aa=new mysql; 

$aa->link(""); 

$query="select * from note info where module id='" 

.$son module id."' and up id='0'"; 

$rst=$aa->excu ($query); 

$num=mysql_ num rows (Srst) 7 

while ($note=mysql fetch array($rst,MYSQL ASSOC)){ 
$query="select * from note info where up id='" 

.$note['id']."' and module id="'0'"; 

$rst=$aa->excu ($query); 
$numt+=mysql_ num rows ($rst); 

} 


return $num; 


A11111111111111111111/ 由 子 板块 的 ia 输出 该 子 板块 的 最 新 帖子 /1/1/171111111111111111 


function son module idtolast note($son module iqd){ 


} 


$aa=new mysql; 
$aa->link(""); 
$query="select * from note info where module id='" 
.$son module id."' order by time desc limit 0,1"; 
$rst=$aa->excu ($query); 
$note=mysql fetch array($rst,MYSQL ASSOC); 
$query2="select * from note info where id='".$note['up id']."'"7 
$rst2=$aa->excu ($query); 
$note2=mysql fetch array($rst2,MYSQL ASSOC); 
echo $note2['title']; 
echo "<br>" 
echo $note['time']."&gnbsp;&nbsp;".$note['user name']; 


A11111111111111111111/ 由 子 板块 的 ia 输出 该 子 板块 的 版 主 ///1VV11111111111111111/ 


function son module idtouser name($son module id){ 


$aa=new mysql; 

$aa->link(""); 

$query="select * from son module info where id='".$son module id."™'"; 
$rst=$aa->excu ($query); 
$module=mysql fetch array($rst,MYSQL ASSOC); 


国 刘 


if ($module['user name']==—""){ 
return "版 主 暂 缺 "; 

}else{ 
return $module['user name']; 


节 下 站 局 几 81 小 鲁 


/11111111111111/ 输 出 所 有 板块 的 下 拉 列 表 ( 子 板块 有 参数 ) /1777771111111111111/ 
function son module list($son module iqd){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from father module info order by id"7 
$rst=$aa->excu ($query); 
echo "<select name=module id>"; 
while ($father module=mysql fetch array($rst,MYSQL ASSOC)){ 
echo "<option value=>".$father module['module name']."</option>"; 
$query="select * from son module info where father module id= '" 
Sfather module[l"id"]ls"" order Dy id 5 
$rst2=$aa->excu ($query); 
while($son module=mysql fetch array($rst2,MYSQL ASSOC)){ 
echo"<option value=".$son module['id'].">&nbsp;&nbsp;" 
.$son module['module name']."</option>"; 


IGG 


} 


echo "</select>"; 


上 
/LAAAAAAAAAAAAAA/ 输 出 父 板块 的 下 拉 列 表 /V/VVAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/ 
function father module list($father module id){ 
$aa=new mysql; 
$aa->link(""); 
echo "<select name=father module id>"; 
if ($father module id=: { 
echo "<option selected> 请 选择 . . .</option>"; 
}elsef{ 
$query= 
"select * from father module info where id='$father module id'"; 
$rst=$aa->excu ($query); 
$father module=mysql fetch array($rst,MYSQL ASSOC); 
echo"<option value=".$father module['id'].">" 
.$father module['module name']."</option>"; 


} 
$query="select * from father module info order by show order"; 
$rst=$aa->excu ($query); 
while($father module=mysql fetch array($rst,MYSQL ASSOC) ) { 
echo "<option value=".$father module['id’'].">" 
-$father module['module name']."</option>"; 
acho "</select>"> 


} 
1111111111111111111/ 由 帖子 的 id 返回 该 帖子 被 浏览 的 次 数 /77777111111111111111717 


function note idtotimes ($note id)f{ 
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$aa=new mysql; 
$aa->link(""); 
$query="select * from note info where id='".$note id."'"; 
$rst=$aa->excu ($query); 
$note=mysql fetch array($rst,MYSQL ASSOC); 
return $note['times']; 
} 
LAM11111111111111111/ 由 帖子 的 iad 返回 该 帖子 的 标题 /1/1771111111111111111/ 
function note idtotitle($note id){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from note info where id='$note id'"7 
$rst=$aa->excu ($query); 
| $note=mysql fetch array($rst,MYSQL ASSOC); 
return $note['title']; 


} 
11M111111111111111111/ 由 帖子 的 ia 返回 帖子 的 回复 数 //77111111111111111111 
function note idtonote num($note id){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from note info where up id='".$note id."'"; 
$rst=$aa->excu ($query); 
$num=mysql num rows ($rst); 
return Snum+17 
LM1LL111111111111/ 由 帖子 的 id 输出 帖子 的 最 后 回复 时 间 /VAAAAAAAAAAAAAAAAAY 
function note idtolast time (Snote_id) { 
$aa=new mysql; 
$aa->link(""); 
$query="select * from note info 
where up_id='$note id' order by time desc limit 0,1"; 
$rst=$aa->excu ($query); 
$note=mysql fetch array($rst,MYSQL ASSOC); 
echo $note['time']; 
1 
///////AAAAAAAAAAAAAA/ 由 帖子 的 id 输出 帖子 的 最 后 回复 人 /AAAAAAAAAAAAAAAAAAAAA 
function note idtolast user name (Snote id){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from note info 
where up id='$note id' order by time desc limit 0,1"; 
$rst=$aa->excu ($query); 
$note=mysql fetch array($rst,MYSQL ASSOC); 
echo $note['user name']; 
} 
111111111111111111111 由 子 板块 的 id 返回 其 父 板块 的 名 称 //7111711111111111111111/ 
function son module idtofather name($son module id){ 
$aa=new mysql; 
$aa->link(""); 


$query="select * from son module info where id='$son module id'"; 


$rst=$aa->excu ($query); 
$module=mysql fetch array($rst,MYSQL ASSOC); 
$query2="select * from father module info 
where id="'$module[father module id]'"; 

$rst2=$aa->excu ($query2); 
$module2=mysql fetch array($rst2,MYSQL ASSOC); 
return $module2['module name']; 

} 

L11111111111111111111/ 由 子 板块 的 id 返回 本 板块 的 名 称 17717111111111111111111 

function son module idtomodule name ($son module id){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from son module info where id='".$son module id." 
$rst=$aa->excu ($query); 
$module=mysql fetch array($rst,MYSQL ASSOC); 
return $module['module name']; 


} 
LMM11111111111111111 所 有 帖子 的 总 数 11711111111111111111111 
function note total num(){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from note info"; 
$rst=$aa->excu ($query); 
return mysql num rows($rst); 
. 
L11111111111111111111 所 有 会 员 的 总 数 11711111111111111111111 
function user total num(){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from user info"; 
$rst=$aa->excu ($query); 
return mysql num rows($rst); 
} 
L1111111111111111111/ 最 后 会 员 名 /177777171711111111111111 
function last username (){ 
$aa=new mysql; 
$aa->link(""); 
$query="select * from user info order by id desc limit 0,1"; 
$rst=$aa->excu ($query); 
$user=mysql fetch array($rst,MYSQL ASSOC); 
return $user['user name']; 


} 
///AAAAAAAAAA/ 分 页 函数 /AAAAAAAAAAAAAAAA/ 
function page ($query, $page_id, $add, $num per page){ 
// include "mysql.inc"; 
/1/1/1111 使 用 方法 为 : 
/////// Smyf=new myfunction; 
/////// $query=""; 
/////// S$myf->page ($query, $page id,$add, $num Per page); 
/////// S$bb=$aa->excu($query); 


地 协 9. 尖 斩 


多 A 
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$bb=new mysql; 
global $query; / /声明 全 局 变量 
$bb->link(""); 
$page_id=@$_ GET['page id']; // 接 受 page_id 
if ($page id==""){ 
$page_id=1; 
} 
$rst=$bb->excu ($query); 
Snum=mysql num rows ($rst); 
if ($num==0){ 
echo "没有 查 到 相关 记录 或 没有 相关 回复 ! <br>"; 


} 
$page_ num=ceil ($num/$num per page); 
for ($i=1;$i<=$page num;$i++){ 
echo "gnbsp; [<a href=?".$add."page id=".$i.">".$i."</a>]"; 
} 
$page_ up=$page id-1; 
$page_down=$page_ id+1; 
if ($page id==1){ 
echo "<a href=?".$add."page id=".$page down 
."> 下 一 页 </a>gnbsp; gnbsp; 第 ".$page_id 
." 页 , 共 ".$page_num." 页 "; 
} 
else if ($page id>=$page num-1){ 
echo "<a href=?".$add."page id=".$page up 
."> 上 一 页 </a>gnbsp; gnbsp; 第 ".$page id 
"页 , 共 ".$page num." 页 "; 
} 
elsei{ 
echo "<a href=?".$add."page id=".$page up 
."> 上 一 页 </a>gnbsp; gnbsp; <a href=?".$add."page id=" 
-Spage_down- "> 下 一 页 </a>&gnbsp; &nbsp; 第 " 
-Spage_id-. a $page_num. 页 ”5 
$page_ jump=$num per page* ($page id-1); 
$query=$query." limit $page jump, $num per page"; 
} 
} //end myfunction 
2> 


18.3.2 ”论坛 主页 面 


论坛 主页 面 的 相关 文件 如 下 。 

文件 head.php 位 于 随 书 光盘 的 chl8\inc\ 下 ， 为 论坛 的 头 文件 ， 代 码 如 下 : 
<?php 

@session start(); 


i 


<style type="text/css"> 
< 
@font-face { 
font-family: "Hanyihei'7 
src: url("inc/hanyihei.ttf") format ("truetype"); 
font-style: normal; } 
@font-face { 
font-family: 'Minijanxixingkai'; 


贡 涉 泪 书 贡 8 名 名 


src: url("inc/minijanxixingkai.ttf") format ("truetype"); 
font-style: normal; } 
-STYLE1 { 
font-family: 'Hanyihei'; 
font-size: 36px; 
color:#024f6c; 


} 
.STYLE2 { 
font-family: 'Hanyihei'; 
一 -> 
</style> 
<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="1"> 
xr 
<td height="60" bgcolor="f0b604"> 
<span class="STYLE1">&nbsp; &nbsp; 迅 捷 BBS 系统 </span> 
</td> 
</tr> 
<tr> 
<td height="2"></td> 
</tr> 
</table> 


文件 foot.php 位 于 随 书 光盘 的 chl8\inc\ 下 ， 为 论坛 的 版 权 文件 。 具 体 代码 如 下 : 


<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
= 
<td height="10"></td> 
et 
<tr> 
<td height="10" bgcolor="#5F8AC5"></td> 
> 
<tr> 
<td height="40" align="center" valign="middle" bgcolor="#f0b604"> 
建议 使 用 浏览 器 IE 6.0 以 上 分 辨 率 1024*768 以 上 <br> 
版 权 所 有 : <a href="http://www.quickbbs.net" target=" blank"> 迅 捷 BBS</a> 
</td> 
< 
</table> 
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文件 total info.php 位 于 随 书 光盘 的 chl8\inc\ 下 ， 为 论坛 的 总 信息 文件 。 具 体 代 码 如 下 : 


<?php 

//@session start(); 

// 用 户 登 录 并 注册 SESSION 

if(isset($_POST[I'tijiao"])){ 
$tijiao=$ POST['tijiao']; 


if (@$tijiao==" 提 交 ") { 

$user name=@$ POST['user name']; 

$user pw=@$ POST['user pw']; 

$check query="select * from user info where user name='".S$user name."'"; 

$check rst=$aa->excu($check query); 

$user=mysql fetch array($check rst); 

if ($user pw==$user['user pw']){ 
$_SESSION['user name']=$user['user name']; 
$today=date ("Y-m-d H:i:s"); 
$query="update user info set time2='".$today.""' 
where user name='".$ SESSION['user name']."'"; 
$aa->excu ($query); 


} 
if (@$tijiao==" 安 全 退出 ") { 
$ SESSION['user name']=""; 
3 
> 
<table width="98%" border="0" align="center" 
I> 


<form id="form]l" name="forml" method="post" action="#"> 
<td width="80%" height="25" align="]left" 
valign="middle" bgcolor= "5F8AC5">&nbsp; 

<?php 

if (@$_SESSION['user name']!=""){ 
echo "<font color=ffffff> 欢 迎 您 :".$_SESSION['user name']."</font>"; 
echo "gnbsp;&nbsp;&nbsp; gnbsp; gnbsp; gnbsp; gnbsp; tnbsp; tnbsp; 
<input type='submit' name='tijiao' value=' 安 全 退出 '>"; 

}elsef{f 

?> 
用 户 名 : 
<input type="text" name="user name" size="8" /> 
密码 :<input type="text" name="user pw" size="8" /> 
<input type="submit" name="tijiao"” value=" 提 交 " /> 
&nbsp; gnbsp;<a href="register.php"> 
<font color="#FFFFFF"> 我 要 注册 </font></a> 

<?php 

2 

2 

</td> 

</form> 


记 


<td width="20%" align="right" valign="middle"”bgcolor="5F8RC5"> 
<?php 
$today=date ("Y-m-d H:i:s"); 
echo $today; 
法 学 
</td> 
</tr> 
tr> 
<td height="25" colspan="2" align="right" valign="middle"> 
帖子 总 数 ， <?php echo $bb->note total num();?>&gnbsp; gnbsp; 
会 员 总 数 : <?php echo $bb->user total num();?>&nbsp; gnbsp; 
欢迎 新 会 员 <?php echo $bb->last username();?>&nbsp; gnbsp;</td> 
</Er> 
Er 
<td height="13" colspan="2" align="right" valign="middle">gnbsp;</td> 
Hx 
</table> 


文件 index.php 位 于 随 书 光盘 的 chl18\ 下 ， 是 用 户 访问 的 主页 。 具 体 代码 如 下 : 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>=== 迅 捷 BBS 系统 ===</title> 
<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<?php 
@session start(); 
include "inc/mysqgl.inc"; 
include "inc/myfunction.inc"; 
include "inc/head.php"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
include "inc/total info.php"; 
?> 
<table class='indextemp' width="98%" border="0" 
align="center" cellpadding="0" cellspacing="]1" bgcolor="#FFFFFF"> 
< 
<td width="50%" height="25" align="center" 
valign="middle" bgcolor="5F8AC5"> 
<span class="STYLE2"> 讨 论 区 </span> 
</td> 
<td width="10%" align="center" valign="middle" bgcolor="5F8AC5"> 
<span class="STYLE2"> 主 题 </span> 
</td> 
<td width="10%" align="center" valign="middle" bgcolor="5F8AC5"> 
<span class="STYLE2"> 帖 子 </span> 
</td> 
<td width="20%" align="center" valign="middle" bgcolor="5F8AC5"> 
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<span class="STYLE2"> 最 新 帖子 </span> 
</td> 
<td width="10%" align="center" valign="middle" bgcolor="5F8AC5"> 
<span class="STYLE2"> 版 主 </span> 
</td> 
</EE> 
ER > 
<td colspan="5"> 
<?php 
$query="select * from father module info order by id"; 
$result=$aa->excu ($query); 
while ($father_ module=mysql fetch array($result)){ 
5 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
dl 省 
<td height="25" colspan="6" bgcolor="98B2CC">gnbsp;&nbsp;&nbsp; &nbsp; 
<img src="pic sys/1i-1.gif" width="16" height="15">&nbsp;é&nbsp;&nbsp; 
<?php echo $father module['module name']?></td> 
</tr> 
<?php 
$query2="select * from son module info where father module id= '" 
.$father module['id']."' order by id"; 
$result2=$aa->excu ($query2); 
while($son module=mysql fetch array ($result2)){ 
Tx 
<tr> 
<td width="5%" height="40" align="center" valign="middle"> 
<img src="pic sys/1i-2.gif" width="32" height="32"> 
</td> 
<td width="45%" align="left" valign="middle"> 
<?php 
echo "<b><a href=module list.php?module id=".$son module['id']."> 
<font color=0000ff>".$son module["module name"] 
“</font></aS</p><br>™"s 
echo $son module["module cont"]; 
re 
</td> 
<td width="10%" align="center" valign="middle"> 
<?php echo $bb->son module idtonote num($son module["id"]);?> 
</td> 
<td width="10%" align="center" valign="middle"> 
<?php echo $bb->son module idtonote num2($son module["id"]);?> 
</td> 
<td width="20%" align="left"” valign="middle"> 
<?php echo $bb->son module idtolast note($son module["id"]);?> 
</td> 
<td width="10%" align="center" valign="middle"> 
<?php echo $bb->son module idtouser name($son module["id"]);?> 
</td> 
</tr> 
<?php }?> 
</table> 


<?php }?> 
</td> 
</tr> 
</table> 
<?php 
include "inc/foot.php"; 
</body> 
</html> 


主页 运行 后 ， 效 果 如 图 18-2 所 示 。 


图 18-2 论坛 主页 面 


18.3.3 ”新 用 户 注册 页 面 
文件 register.php 位 于 随 书 光盘 的 sh18\ 下 ， 是 新 用 户 注册 页 面 。 具 体 代 码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>=== 迅 捷 BBS 系统 ===</title> 

<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 

<body> 

<?php 

include "inc/mysql.inc"; 

include "inc/myfunction.inc"; 

include "inc/head.php"; 

$aa=new mysql; 

$bb=new myfunction; 

$aa—>link(""); 

include "inc/total info.php"; 

?> 

<table width="98%" border="0" align="center" 
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cellpadding="0" cellspacing="0"> 
“EE 
<td width="73%"” height="30"><a href="./"> 迅 捷 B B S 系统 </a>>> 新 用 户 注册 
</td> 
<td width="27%" align="right" valign="middle"> 
<a href="new note.php"></a> 
</td> 
</tr> 
</table> 
<table width="98%" border="0" align="center" cellpadding="0" 
cellspacing="1" bgcolor="#FFFFFF"> 
<tr> 
<td height="25" align="center" valign="middle" bgcolor="5F8AC5"> 
| 发 布 新 帖 
</td> 
二 
EE 
<td height="25" align="center" valign="middle"> 
<?php 
// 接 收 提交 表单 内 容 ， 检 验 数 据 库 中 是 否 已 经 存在 此 用 户 名 ， 不 存在 则 写 入 数据 库 
$tijiao=@$ POST['tijiao']; 
if ($tijiao==" 提 交 ") { 
$user name=@$ POST['user name']; 
$query="select * from user info where user name='$user name'™"; 
$rst=$aa->excu ($query); 
if (mysql num rows($rst)!=0){ 
echo "=== 您 注册 的 用 户 名 已 经 存在 ， 请 选择 其 他 的 用 户 名 重新 注册 ! ==: 
}elsef{ 
$user pwl=$_ POST['user pwl']; 
$user pw2=$_POST['user pw2°']; 
if ($user pwl!=$user pw2){ 
echo "=== 您 两 次 输入 的 密码 不 匹配 ， 请 重新 输入 ! 
}elsef{ 
$today=date ("Y-m-d H:i:s"); 
$query="insert into user info(user name,user pw,timel) 
values('$user name','$user pwl','$today')"; 
if ($aa->excu($query)){ 
echo "=== 恭 喜 您 ， 注 册 成 功 ! 请 <a href=../> 
返回 主页 </a> 登 录 
$register tag=1; 


} 


} 

// 显 示 注册 表单 

if (@$register tag!=1){ 
2> 


<form name="forml" method="post" action="#"> 
<table width="500" border="0" cellpadding="0" cellspacing="2"> 


a 


<td width="122"”height="26"”align="right" 
valign="middle" bgcolor="#CCCCCC"> 
用 户 名 : 
</td> 
<td width="372" height="26" align="]left" 
valign="middle" bgcolor="#CCCCCC"> 
<input type="text" name="user name"> 
</td> 
</tr> 
<tr> 


<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 密 码 : 


</td> 


<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 


<input type="text" name="user pwl"> 
</td> 
</tr> 
这 


<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 


重复 密码 : 
</td> 


<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 


<input type="text" name="user pw2"> 
</td> 


"26" colspan="2" align="center" valign="middle" 
bgcolor= "#CcCCCcc"> 
<input type="submit" name="tijiao” value=" 提 交 "> 
&nbsp; gnbsp; &nbsp; &nbsp; 
<input type="reset" name="Submit2" value=" 重 置 "> 
</td> 
</tr> 
</table> 
</form> 
<?php 
} 
?> 
</td> 
</Exr> 
i 
<td height="1" bgcolor="#CCCCCC"></td> 
二 WE 
</table> 
<?php 
include "inc/foot.php"; 
Se 
</body> 
</html> 


注册 页 面 的 运行 效果 如 图 18-3 所 示 。 输 入 用 户 名 和 密码 后 ， 单 击 “提交 ”按钮 ， 


id 二 a 兴 二 
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A 


图 18-3 新 用 户 注册 页 面 


注册 完成 后 ， 即 可 在 主页 输入 用 户 名 和 密码 ， 单 击 “ 提 交 ” 按 钮 ， 登 录 论坛 系统 。 登 录 
后 的 效果 如 图 18-4 所 示 。 单 击 “ 安 全 退出 ”按钮 ， 即 可 退出 登录 操作 。 


18-4 用 户 成功 登录 


18.3.4 “论坛 帖子 的 相关 页 面 


下 面 介 绍 论坛 帖子 的 相关 页 面 。 
文件 new_note.php 位 于 随 书 光盘 的 ch18\ 下 ， 是 用 于 发 布 新 帖 的 页 面 。 具 体 代 码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>=== 迅 捷 BBS 系统 ===</title> 

<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 

<body> 

<?php 

//@session start(); 

include "inc/mysql.inc"; 

include "inc/myfunction.inc"; 

include "inc/head.php"; 

$aa=new mysql; 

$bb=new myfunction; 

$aa->link(""); 

include "inc/total info.php"; 
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2 
<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
Er 
<td width="73%" height="30"><a href="./"> 迅 捷 B B S 系统 </a>>> 发 新 帖子 </td> 
<td width="27%" align="right" valign="middle"><a href="new note.php"> 
<img src="pic sys/post.gif" width="82" height="20"></a></td> 
坏人 七天 大 
</table> 


<table width="98%" border="0" align="center" cellpadding="0" 


cellspacing="1" bgcolor="#FFFFFF"> 
区 
<td height="25" align="center" valign="middle" bgcolor="5F8AC5"> 
发 布 新 帖 </td> 
</tr> 
2 
<td height="25" align="center" valign="middle"> 
<?php 
if (@$_ SESSION['user name']==""){ 
echo " 


}elsef{ 
// 接 收 提交 表单 内 容 ， 写 入 数据 库 
$tijiao=@$ POST['tijiao']; 
if ($tijiao==" 提 交 ") { 
$module id=@$ POST['module id']; 
$title=@$ POST['title']; 
$cont=@$ POST['cont']; 


PHP+MySQL 动 态 网 站 开发 
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$cont=$bb->str to($cont); 
$today=date ("Y-m-d H:i:s"); 
if ($module id!="" and $title!="" and $cont!=""){ 
$query= 
"insert into note info (module id,title,cont,time,user name) 
values('$module id','$title','$cont','$today','" 
.$ SESSION['user name']."')"; 
if ($aa->excu($query)){ 
echo "=== 新 帖 发 布 成 功 ， 请 继续 ! 
} 
J}elsef{ 
echo "=== 请 选择 子 模块 ， 而 且 标 题 和 内 容 均 不 能 为 空 ! = 


二 
3 
<form name="forml" method="post" action="new note.php"> 
<table width="500" border="0" cellpadding="0" cellspacing="2"> 
<tr> 
<td width="122" height="26" align="right" 
valign="middle"” bgcolor="#CCCCCC"> 隶 属 板块 :</td> 
<td width="372" height="26" align="left" 
valign="middle" bgcolor="#CCCCCC"> 
<?php 
$bb->son module list(""); 
?> 
</td> 
2 二 二 
> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 标 题 : 
</td> 
<td height 
<input type= 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 内 容 : 
</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
<textarea name="cont" cols="50" rows="8"></textarea></td> 


"26" align="left" valign="middle" bgcolor="#CCCCCC"> 
text" name="title"></td> 


</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 
发 帖 人 :</tad> 


<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
&nbsp; <?php echo $_ SESSION['user name'];?></td> 
< Er 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 时 间 : 
</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
系统 将 自动 记录 ! </td> 


</tr> 
<tr> 
<td height="26" colspan="2" align="center™" 
valign="middle" bgcolor="#CCCCCC"> 


<input type="submit" name="tijiao” value=" 提 交 "> 


&nbsp; gnbsp; Enbsp; gnbsp; 


<input type="reset" name="Submit2"” value=" 重 置 "> 


</td> 
</tr> 
</table> 
</form> 
<?php 
2> 
</td> 
</tr> 
<tr><td height="1" bgcolor="#CCCCCC"></td></tr> 
</table> 


<?php 

include "inc/foot.php"; 

?> 

</body> 

</html> 

发 布 新 帖 的 页 面 效果 如 图 18-5 所 示 。 


帖子 总 数 : 0 会 员 总 数 : 1 欢迎 新 会 员 : aaa 


18-5 ”发 新 帖 页 面 


RN 


ba 
oO 
会。 
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文件 note_ show.php 位 于 随 书 光盘 的 ch18\ 下 ， 是 显示 帖子 和 相关 回复 的 页 面 。 具 体 代 码 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>=== 迅 捷 BBS 系统 ===</title> 

<link href="inc/style.css" rel="stylesheet" type="text/css" /> 

</head> 
<body> 
<?php 
include 


nc/mysql.inc"; 

include "inc/myfunction.inc"; 

include "inc/head.php"; 

$aa=new mysql; 

$bb=new myfunction; 

$aa->link(""); 

include "inc/total info.php"; 

$module id=$ GET[module id]; 

$note id=$ GET[note id]; 

?> 

<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 

< 

<td width="73%" height="30"><a href="./"> 迅 捷 B B S 系统 </a>>> 
<?php 
echo "<a href=module list.php?module id=".$module id.">"; 
echo $bb->son module idtofather name ($module id); 
echo "</a>>>"; 
echo $bb->son module idtomodule name ($module id); 


// 删 除 回复 


$del id=$ GET[del id]; 
if ($del id!=""){ 
if ($bb->son module idtouser name ($module id)==$ SESSION[user name]){ 
$del query="delete from note info where id='$del id'"; 
$aa->excu ($del query); 


} 

// 添 加 回复 

$tijiao=$ POST[tijiao]; 

证 ($tijiao==" 提 交 ")1{ 
$title=$ POST[title]; 
$cont=$_POST[cont]; 
$cont=$bb->str tol($cont); 
$today=date ("Y-m-d H:i:s 
if ($ SESSION[user name]== 

$user name=" 游 客 "; 
jelset 
$user name=$ SESSION[user name]; 


St 


加 


$query="insert into note info(up id,title,cont,time,user name) 
Values('$note id','$title','$cont','s$today', '$user name')"™; 
$aa->excu ($query); 
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} 

?></td> 

<td width="16%" align="right" valign="middle"><a href="#huifu"> 
img sr pic sys/reply.gif" width="82" height="20"></a></td> 


<td width="11%" align="right" valign="middle"><a href="new note.php"> 
<img src="pic sys/post.gif" width="82" height="20"></a></td> 
WE 二 
</table> 
<?php 
$query="select * from note info where up id='$note id' order by time"; 
$add="module id=".$module id."&note id=".$note id."g"; 
人 > 
<table width="98%" border="0" align="center" cellpadding= 
<tr> 
<td height="30" align="]left" valign="middle"> 
<?php $bb->page ($query, $page id,$add,20)?> 
</td> 
</tr> 
</table> 
<?php 
$query2="select * from note info where id='$note id'"; 
$result2=$aa->excu ($query2); 
$note2=mysql _ fetch array ($result2); 
> 
<table width="98%" border="0" align="center" cellpadding= 
bgcolor="#FFFFFF"> 
<tr> 
<td width="71%" height="25" align="]left" 
valign="middle" bgcolor="5F8AC5"> 标 题 : 
<?php 
echo $note2[title]?></td> 
<td width="29%" align="center" valign="middle" bgcolor="5F8AC5"> 
发 帖 时 间 : <?php echo $note2 [time]?></td> 
</tr> 
<tr> 
<td height="1" colspan="2" bgcolor="#CCCCCC"></td> 
Er> 
</table> 
<table width="98%" border=" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td width="16%" height="15"” align="center" valign="top"> 
<img src="pic sys/head?2.jpg" width="85" height="90"><br> 
<?php echo $note2[user name]?></td> 
<td align="left" valign="middle"><?php echo $note2[cont]?></td> 
</tr> 
EE 


0" cellspacing="0"> 


GG 
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<td height="8" colspan="2" align="center" 
valign="top" bgcolor="#5F8AC5"> 
</td> 
过 NEE> 
</table> 
<?php 
$rst=$aa->excu ($query); 
if (mysql num rows($rst)!=0){ 
?> 
<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<?php 
while ($note=mysql fetch array($rst)){ 
?> 
<tr> 
<td width="16%" height="120" rowspan="3" align="center" valign="top"> 
<?php 
if ($note[user name]==" 游 客 ") { 
?> 
<img src="pic_ sys/headl.png" width="100" height="100"> 
<br> 
游客 
<?php 
}elsef 
> 
<img src="pic_ sys/head2.jpg" width="85" height="90"><br> 
<?php 
echo $note[user name]; 
} 
?></td> 
<td width="54%" height="26" align="left” valign="middle"> 
<?php echo $note[title]?></td> 
<td width="18%" height="26" align="center" valign="middle"> 
<?php echo $note[time]?></td> 
<td width="12%" height="26" align="center" valign="middle"> 
<?php 
if ($bb->son module idtouser name (Smodule id)==$ SESSION[user name] 
11 $_SESSION[manage tag]==1){ 
echo "<a href=? module id=".$module id."&note id=".$note id 
."&page id=".$page id."&gdel id=".$note[id]."> 删 除 回 复 </a>"; 


} 
?></td> 
</Exs 
ee 
<td height="1" colspan="3" align="]left" 
valign="top" bgcolor="#CCCCCC"></td> 
/Er 
EE> 
<td height="70" colspan="3" align="left" valign="top"> 
<?php echo $note[cont]?></td> 


U 


到 KE 
<tr> 
<td height="2" colspan="4" align="center 
valign="top" bgcolor="#CCCCCC"></td> 
Er 
<?php }?> 
</table> 
<?php 
} 
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> 
<table width="98%" border="0" align="center" 


cellpadding="0" cellspacing="0"> 

和 
<td height="30" align="right" valign="bottom"> 
<?php 


$query="select * from note info 
where up_id='$note id' order by time desc"; 
$bb->page ($query, $page_id, $add, 20); 
?></td> 
</tr> 
</table> 
<form name="forml" method="post" action="#"> 
<table width="500" border="0" align="center" 
cellpadding="0" cellspacing="2"> 
< 
<td height="26" colspan="2" align="center" 
valign="middle" bgcolor="#CCCCCC"> 
<a name="huifu"> 回 复 此 帖 </a></td> 
二 /大 
<tr> 
<td width="122" height="26" align="right" valign="middle" 
bgcolor="#CCCCCC"> 标 题 :</td> 
<td width="372"” height="26" align="1left"” valign="middle" 
bgcolor="#CCCCCC"> 
<?php 
$reply title=" 回 复 :" .$bb->note idtotitle ($note id); 
echo S$reply title; 


GG 


2> 
<input type="hidden" name="title" value="<?php echo S$reply title?>"> 
</tad> 

<XEF> 

< 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 内 容 : 
</td> 
<td height="26" align="]left" valign="middle" bgcolor="#CCCCCC"> 

<textarea name="cont" cols="50" rows="8"></textarea></td> 

/Er 

<Er 
<td height="26" align="right" valign="middle"™ bgcolor="#CCCCCC"> 发 帖 人 : 
</td> 
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-案例 课堂 >… 


<td height="26" align="left" valign="middle" bgcolor="#CCCCCC">&nbsp; 
<?php 
if ($_SESSION[user name]==""){ 
echo "游客 "; 
}else{ 
echo $_SESSION[user name]; 
} 
?></td> 
</tr> 
<Etr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCccc"> 时 间 : 
</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
系统 将 自动 记录 ! </td> 
</tr> 
<tr> 
<td height="26" colspan="2" align="center" 
valign="middle" bgcolor="#CCCCCC"> 
<input type="submit" name="tijiao"” value=" 提 交 "> 
&nbsp; Enbsp; gnbsp; gnbsp; 
<input type="reset" name="Submit2"” value=" 重 置 "></td> 
</tr> 
</table> 
</form> 
<?php 
include "inc/foot.php"; 
</body> 
</html> 


回复 帖子 页 面 的 效果 如 图 18-6 所 示 。 


18-6 ”回复 帖子 页 面 


文件 module_ listphp 位 于 随 书 光 盘 的 ch18\ 下 ， 是 显示 子 模块 下 帖子 列表 的 页 面 。 具 体 代 
码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 

<title>=== 迅 捷 BBS 系统 ===</title> 

<link href="inc/style.css" rel="stylesheet" type="text/css" /> 

</head> 

<body> 

<?php 

@session start(); 

include "inc/mysql.inc"; 

include "inc/myfunction.inc"; 

include "inc/head.php"; 

$aa=new mysql; 

$bb=new myfunction; 

$aa->link(" 

include "inc/total info.php"; 

$module id=@$ GET['module id']; 

$del id=@$ GET['del id']; 

if ($bb->son module idtouser name ($module id)==@$ SESSION['user name']){ 
$query="delete from note info where id='".$del id."'"; 
$aa->excu ($query); 


. 
$query="select * from note info where module id='" 
.$module id."' order by time desc"; 
$add="module id=".$module id."g"; 
?> 
<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td width="73%" height="30"><a href="./"> 迅 捷 B B S 系统 </a>>> 
<?php 
echo "<a href=module list.php?module id=".$module id.">"; 
echo $bb->son module idtofather name ($module id); 
echo "</a>>>"; 
echo $bb->son module idtomodule name ($module id); 
?></td> 
<td width="27%" align="right" valign="middle"><a href="new note.php"> 
<img src="pic sys/post.gif" width="82" height="20"></a></td> 
/ER 
</table> 
<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td height="30" align="left" valign="middle"> 
<?php $bb->page ($query,@$page id,$add,20)?></td> 
Hr 
</table> 


本 刘 
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<table width="98%" border: align="center" cellpadding="0" 
cellspacing="]1" bgcolor="#FFFFFF"> 
长 攻 六 
<td width="3%" height="25" align="center" valign="middle" 
bgcolor="5F8AC5">&nbsp;</td> 
<td width="5%" align="center" valign="middle"™" bgcolor="5F8AC5"> 人 气 </td> 
<td width="50%" align="center" valign="middle" bgcolor="5F8AC5"> 标 题 


</td> 
<td width="9%" align="center" valign="middle" bgcolor="5F8AC5"> 发 起 人 
</td> 
<td width="5%" align="center" valign="middle" bgcolor="5F8AC5"> 帖 子 数 
</td> 
<td width="16%" align="center" valign="middle" bgcolor="5F8AC5"> 
最 后 发 表 时 间 </td> 
<td width="12%" align="center" valign="middle" bgcolor="5F8AC5"> 
最 后 发 表 人 </td> 
</tr> 
<?php 


$result=$aa->excu ($query); 
while($note=mysql fetch array ($result)){ 
> 
EE 
<td height="25" align="center" valign="middle"> 
<img src="pic sys/1i-3.gif" width="14"”height="11"></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtotimes ($note['id']);?></td> 
<td height="25" align="]left" valign="middle"> 
<?php 
echo "<a href=note_ show.php?module id=".$module id 
."&note id=".$note['id'].">".$note['title']."</a>"; 
if ($bb->son module idtouser name ($module id)==$ SESSION['user name'] 
11 $_SESSION['manage tag']==1){ 
echo "gnbsp;&nbsp; 
<a href=module list.php?module id=".$module id 
."&gpage id=".$page id."&gdel id=".$note['id']."> 删 除 此 帖 </a>"; 
} 
?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $note['user name'];?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtonote num($note['id']);?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtolast _ time ($note['id']);?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtolast user name($note['id']);?></td> 
</Er> 
3 
<td height="1" colspan="7" bgcolor="#CCCCCC"></td> 
< 
<?php 


} 
2 
</table> 
<table width="98%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
ES 
<td height="30" align="right" valign="bottom"> 
<?php 
$query="select * from note info where module id='" 
.$module id."' order by time desc"; 
$bb->page ($query, @$page id, $add, 20) 
?></td> 
</Ez> 
</table> 
<?php 
include "inc/foot.php"; 
站 入 
</body> 
</html> 


显示 帖子 的 页 面 效 果 如 图 18-7 所 示 。 


[Brepyioc- Bo- Bo 


贴 子 总 数 ; 0 会 员 息 数 ; 1 欢迎 新 会 员 ; aaa 


迅 到 BBS 系 纺 >> >> 
设 有 查 到 相关 记录 或 设 有 相关 回复 
下 一 页 第 ! 贡 共 ( 页 


有 查 到 相关 记录 或 没有 相关 辐 复 
下 一 页 第 1 页 共 (页 


18-7 ”显示 帖子 列表 的 页 面 


18.3.5 后台 管理 系统 的 相关 页 面 


下 面 介绍 后 台 管 理 系统 的 相关 页 面 。 
(1) login.php 位 于 随 书 光盘 的 chi8manage\ 下 ， 用 于 管理 用 户 登 录 。 具 体 代码 如 下 : 


PHP+MySQL 动 态 网 站 开发 
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<?php 

include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 

$bb=new myfunction; 
$aa->link(""); 

$ SESSION['manage name']=""; 

$ SESSION['manage tag']= 
了 全 

<head> 

<style> 

二 二 

td { font-size: 10pt } 

一 -> 

</style> 

Ee 
</head> 
<body onLoad="tijiao.username.value='';tijiao.username.focus();"> 
<p align="center"></p> 

<br> 

<div align="center"> 


管理 员 登 录 == 迅 捷 BBs 系统 : : :</title> 


<center> 
<form method=POST name="tijiao" action="auth.php"> 
<table border="1"” cellpadding="0" cellspacing="0" bordercolor="#111111" 
width="240" height="126" bordercolorlight="#FFFFFF" 
bordercolordark="#FFFFFF" style="border-collapse: collapse"> 
x 
<td width="238" colspan= 
<p align="center"> 
<b><font color="#FFFFFF"> 迅 捷 BBS 后 台 管理 系统 </font></b> 
<NEd> 
</tr> 
< 
<td width="64" height="26" bgcolor="#E3El1E6"> 
<p align="center"> 账 gnbsp; 号 : </td> 
<td height="26" bgcolor="#E3El1E6" width="173"> 
<input type="text" name="username" size="20" 
style="color: #A8A3AD; border-style: solid; 
border-width: 1; padding-left: 4; padding-right: 4; 
padding-top: 1; padding-bottom: 1"></td> 
</tr> 
“PE 
<td width="64" height="26" bgcolor="#E3El1E6"> 
<p align="center"> 口 snbsp; 令 : </td> 
<td height="26"”bgcolor="#E3E1E6"” width="173"> 
<input type="password" name="password" size="20" 
style="color: #A8A3AD; border-style: solid; 
border-width: 1; padding-left: 4; padding-right: 4; 
padding-top: 1; padding-bottom: 1"></td> 
SET 


height="25" bgcolor="#A8A3AD"> 


<tr> 
<td width="238" height="29" bgcolor="#E3E1E6" colspan="2"> 
<p align="center"><input type="submit" value=" 登 录 " name="login"> 
&nbsp; gnbsp; Enbsp; gnbsp; 
<input type="reset™ value=" 取 消 " name="cancel"></td> 
</tr> 
<EE> 
<td width="238" colspan="2" height="20" bgcolor="#A8A3AD"></td> 
</tr> 
</table> 
</form> 
</center> 
</div> 
</body> 


管理 用 户 登录 页 面 的 效果 如 图 18-8 所 示 。 


[一 -局 


国 古 于 x 
— Reareeseeeeeeeeeeeeeeeecaeeeeeeeeeees5EEaeaeaed 
I@ Sno/oc. B po- Sox| locahost | 


文件 (有 ) ”编辑 (E) ”可 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


迅捷 BBS 后 台 管 理 系统 


账 号 ; 
口令 : 


图 18-8 ”管理 用 户 登 录 的 页 面 
(2) 文件 session.inc 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 检验 Session 是 否 存在 的 页 面 。 


具体 代码 如 下 : 


<?php 

@session start(); 

//if ($_SESSION['manage name']=="" and $_ SESSION['manage tag']!=1){ 
Hp header ("location:./login.php"); 

A } 

和 


(3) 文件 index_top.php 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 后 台 管 理 主页 面 的 上 部 页 
具体 代码 如 下 : 


<HTML> 

<HEAD> 

<TITLE> 顶 部 管理 导航 菜单 </TITLE> 

<META http-equiv=Content-Type content="text/html; charset=gb2312"> 
<STYLE type=text/css> 


PHP+MySQL 动 态 网 站 开发 
案例 课堂 


merlink 于 

COLOR : #ffffff; TEXT-DECORATION: none 
A:hover { 

COLOR: #ffffff 
A:visited { 

COLOR: #f£f0f0f0; TEXT-DECORATION: none 
F 
-Spa { 

FONT-SIZE: 9pt; FILTER: Glow(Color=#0F42A6, Strength=2) dropshadow 
(Color=#0F42A6, OffX=2, OffY=1,); COLOR: #8aade9; FONT-FAMILY: ' 宋 体 ' 
} 

IMG { 
FILTER: Alpha(opacity:100); chroma: #FFFFFF) 


， 
</STYLE> 
<SCRIPT language=JavaScript type=text/JavaScript> 
function PreloadImg (src) { 

Var img=new Image () 7 

img.src=src 
3 
preloadImg ('image/admin top open.gif'); 
var displayBar=true; 
function switchBar(obj) { 

if (displayBar) { 
parent.frame.cols='0,*'; 
displayBar=false; 
obj.src='image/admin top open.gif'; 
obj .title=' 打 开 左边 管理 导航 菜单 '; 
else { 
parent.frame.cols="'200,*'; 
displayBar=true; 
obj.src='image/admin top close.gif'; 


obj .title=' 关 闭 左 边 管理 导航 菜单 '; 


. 
</SCRIPT> 
<META content="MSHTML 6.00.2900.2963" name=GENERATOR></HEAD> 
<BODY leftMargin=0 background=image/admin top bg.gif topMargin=0> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR vAlign=center> 
<TD width=60><IMG title= 关 闭 左 边 管理 导航 菜单 style="CURSOR: hand" 
onclick=switchBar (this) src="image/admin top close.gif"></TD> 
<TD width=92><A href="login.php" target=" parent"> 
<IMG src="image/top an 1.gif" border=0></A></TD> 
<TD width=92><A href="#"></A></TD> 
<TD width=104><A href="#"></A></TD> 
<TD width=92><A href="#"></A></TD> 


<TD width=92><RA href="#"></A></TD> 
<TD class=spa align=right>ET PHP SOUND CODE DEVELOP &nbsp7 
</TD> 
</TR> 
</TBODY> 
</TABLE> 
</BODY> 
</HTML> 


(4) 文件 index_leftphp 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 后 台 管 理 主页 面 的 左 侧 页 
具体 代码 如 下 : 


<?php 
include "session.inc"; 
人 
<HTML> 
<HEAD><TITLE> 管 理 导航 菜单 </TITLE> 
<META http-equiv=Content-Type content="text/html; charset=gb2312"> 
<SCRIPT src="menu.js"></SCRIPT> 
<LINK href="left.css" type=text/css rel=stylesheet> 
</HEAD> 
<BODY leftMargin=0 topMargin=0 marginwidth="0" marginheight="0"> 
<TABLE cellSpacing=0 cellPadding=0 width=180 align=center border=0> 
<TBODY> 
<TR> 
<TD vAlign=top height=44><IMG src="image/title.gif"></TD> 
</TR></TBODY> </TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=180 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTit1le0 
onmouseover="this.className='menu title2';" 
onmouseout="this.className='menu title';" 
background=image/title bg quit.gif 
height=26>gnbsp; gnbsp;<A href="Admin Main.php" target=" top"> 
<B><SPAN class=glow> 管 理 首页 </SPAN></B></A> 
<SPAN class=glow>|</SPAN><A href="login.php" target=" top"> 
<B><SPAN class=glow> 退 出 </SPRN></B></R></TD></TR> 
<TR> 
<TD id=submenu0 background=image/title bg admin.gif height=97> 
<DIV style="WIDTH: 180px"> 
<TABLE cel1Spacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=16> 您 的 用 户 名 : <?php echo @$_SESSION ['manage name'];?> 
</TD></TR> 
<TR> 
<TD height=16> 您 的 身份 : <?php echo @$_SESSION['manage name'];?> 
</TD></TR> 
<TR> 
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<TD height=16>IP: <?php echo $_SERVER["REMOTE ADDR"];?></TD> 
</TR> 
<TR> 
<TD height=16>&gnbsp;</TD> 
</TR> 
</TBODY></TABLE></DIV> 
<DIV style="WIDTH: 167px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=20></TD></TR></TBODY> 
</TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitlel 
onmouseover="this.className='menu title2'" style="CURSOR: hand" 
onclick="new Element.toggle('submenul')" 
onmouseout="this.className='menu title'" 
background=image/Admin left 1.gif height=28 ;> 
<SPAN class=glow> 论 坛 板块 管理 </sPAN></TD> 
</TR> 
<TR> 
<TD id=submenul style="DISPLAY: none" align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellSpacing=0 cellPadding=0 width=132 align=center> 
<TBODY> 
<TR> 
<TD height=20><A href="father module_add.php”target=main> 父 板块 添加 
</A></TD> 
</TR> 
<TR> 
<TD height=20><A href="father module list.php" target=main> 
父 板块 管理 </A></TD> 
</TR> 
<TR> 子 板块 添加 </A></TD> 
</TR> 
<TR> 
<TD height=20><A href="son module list.php" target=main> 
子 板块 管理 </A></TD> 
</TR> 
</TABLE> 
</DIV> 
<DIV style="WIDTH: 158px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=4></TD></TR> 
</TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 


加 


<TBODY> 
<TR> 
<TD class=menu title id=menuTitle2 
onmouseover="this.className='"'menu title2'" style="CURSOR: hand" 
onclick="new Element.toggle('submenu2°')" 
onmouseout="this.className='menu title'™" 
background=image/Admin left 11.gif height=28 ;> 
<SPAN class=glow> 论 坛 用 户 管理 </sPAN></TD> 
</TR> 
<TR> 
<TD id=submenu2 style="DISPLAY: none" align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellSpacing=0 cellPadding=0 width=132 align=center> 
<TBODY> 
<TR> 
<TD height=20><A href="user list.php" target=main> 所 有 用 户 </A></TD> 
</TR> 
<TR> 
<TD height=20><A href="user js.php”target=main> 用 户 检 索 </A></TD> 
</TR> 
</TBODY></TABLE> 
</DIV> 
<DIV style="WIDTH: 158px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=4></TD></TR> 
</TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitle3 
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onmouseover="this.className='menu title2'" style="CURSOR: hand" 
onclick="new Element.toggle('submenu3')" 
onmouseout="this.className='menu title'" 
background=image/Admin left 3.gif height=28 ;> 
<SPAN class=glow> 安 全 管理 </SPAN></TD> 
</TR> 
<TR> 
<TD id=submenu3 style="DISPLAY: none" align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellsSpacing=0 cellPadding=0 width=132 align=center> 
<TBODY> 
<TR> 
<TD height=20><A href="user pw_change.php” target=main> 密 码 更 改 </A> 
</TD> 
</TR> 
<TR> 
<TD height=20><A href="../" target= blank> 帖 子 管理 </A></TD> 
</TR> 
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</TBODY></TABLE> 
</DIV> 
<DIV style="WIDTH: 158px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=4></TD></TR> 
</TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSsSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitle208 
onmouseover="this.className='menu title2';" 
onmouseout="this.className='menu title';" 
background=image/Admin left 04.gif 
height=28><SPAN> 系 统 信 息 </SPAN> </TD></TR> 
<TR> 
<TD align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=20><br> 版 本 号 :verson 1.0<BR> 版 权 所 有 : &nbsp7 
<A href= "http://www.quickbbs.net/” target= _blank> 迅 捷 BBS</R> 
<BR> 设 计 制 作 : gnbsp; 
<A href="http://www.etpt.net/"” target= blank> 迅 捷 BBS</A> 
<BR> 技 术 支 持 : gnbsp; 
<A href="http://bbs.etpt.net/"” target= blank> 迅 捷 BBS</A> 
<BR><BR></TD></TR> 
</TBODY></TABLE></DIV></TD></TR> 
</TBODY></TABLE> 
</BODY> 
</HTML> 


(5) 文件 index_right.php 位 于 随 书 光盘 的 chl18\manage\ 下 ， 是 后 台 管 理 主页 面 的 右 侧 页 
面 。 具体 代码 如 下 : 


<?php 
include "fun head.php"; 
head ("管理 首页 ") ; 
?> 
<TABLE cel1Spacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20 rowSpan=2>&nbsp;</TD> 
<TD class=topbg align=middle width=100> 论 坛 板块 管理 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=40 rowSpan=2>gnbsp;</TD> 
<TD class=topbg align=middle width=100> 论 坛 用 户 管理 </TD> 
<TD width=300>&nbsp7</TD> 


<TD width=21 rowSpan=2>&gnbsp;</TD></TR> 
<TR class=topbg2> 
<TD colSpan=2 height=1></TD> 
<TD colSpan=2></TD></TR></TBODY></TRBLE> 
<TABLE cel1Spacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20>gnbsp;</TD> 
<TD width=400><br> 
本 管理 模块 共 分 四 个 子 模块 : 父 模块 添加 、 父 模块 管理 、 子 模块 添加 、 子 某 块 管理 。 
其 中 父 模块 添加 和 子 模块 添加 可 以 实现 本 论坛 的 父 模块 和 子 模块 的 添加 ; 
父 模块 的 管理 和 子 模块 的 管理 可 以 实现 本 论坛 父 模块 和 子 模块 的 删除 、 编 辑 等 功能 。<BR> 
</TD> 
<TD width=40>gnbsp;</TD> 
<TD 
width=400><br> 
本 管理 模块 共 分 两 个 子 模块 :所 有 用 户 和 用 户 检索 。 
其 中 所 有 用 户 按 用 户 注册 的 先后 顺序 分 页 依次 列 出 。 
用 户 检索 是 有 管理 员 输入 要 查询 的 论坛 注册 用 户 的 用 户 名 ， 系 统 通过 数据 库 查 询 出 该 用 户 的 
相关 信息 ， 并 列 出 ， 而 且 管 理 员 也 可 以 在 查询 注册 用 户 后 直接 删除 该 用 户 。<br> 
<br></TD> 
<TD width=21>gnbsp;</TD></TR></TBODY></TABLE> 
<TABLE height=10 cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20 rowSpan=2>&nbsp;</TD> 
<TD class=topbg align=middle width=100> 安 全 管理 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=40 rowSpan=2>&nbsp;</TD> 
<TD class=topbg align=middle width=100> 系 统 信息 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=21 rowSpan=2>&nbsp;</TD></TR> 
<TR class=topbg2> 
<TD colSpan=2 height=1></TD> 
<TD colSpan=2></TD></TR></TBODY></TABLE> 
<TABLE cel1Spacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20>gnbsp;</TD> 
<TD 
width=400><br> 
本 管理 模块 共 分 两 个 子 模块 :密码 更 改 和 帖子 管理 。 
其 中 密码 更 改 提供 了 管理 员 更 改 密码 的 功能 ， 但 必须 输入 原 密 码 和 两 次 新 密码 ; 
帖子 管理 是 直接 进入 论坛 的 主 界面 ， 但 与 普通 注册 用 户 所 不 同 的 是 ， 
在 论坛 的 每 个 发 帖 和 回复 后 面 都 多 了 一 个 删除 按钮 ， 可 以 通过 此 按钮 删除 相关 帖子 或 回复 。</TD> 


<TD width=40>gnbsp;</TD> 
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<TD 
width=400 valign="top"><br /> 
本 模块 提供 了 本 论坛 的 版 本 号 、 版 权 所 有 、 设 计 制 作 以 及 技术 支持 等 信息 。</TD> 
<TD width=21>gnbsp;</TD></TR></TBODY></TABLE> 
<TABLE height=70 cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD></TD></TR></TBODY></TABLE> 
<TABLE height=10 cellSspacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD></TD></TR></TBODY></TABLE> 
<BR> 
| <?php 
include "bottom.php"; 
和 


(6) 文件 bootom.php 位 于 随 书 光盘 的 chl8wmanage\ 下 ， 是 后 台 管 理 主页 面 的 版 权 页 面 。 
具体 代码 如 下 : 


<TABLE class=border cellSpacing=1 cellPadding=2 width="100%" align=center 
border=0> 
<TBODY> 
<TR align=middle> 
<TD class=topbg height=25> 
<SPAN class=Glow>Copyright 2012 gcopy; 
<a href=" /www.quickbbs.net" target=" blank"> 
<font color="#FFFFFF"> 迅 捷 BBS</font></a> 
All Rights Reserved.</SPRN> 
</TD></TR> 
</TBODY> 
</TABLE> 


(7) 文件 index.php 位 于 随 书 光盘 的 ch18\manage\ 下 ， 是 后 台 管 理 的 主页 面 。 代 码 如 下 : 


<?php 
include "session.inc"; 
时 > 
<HTML> 
<HEAD> 
<TITLE>=== 迅 捷 BBS 系统 -后 台 管理 ===</TITLE> 
<META http-equiv=Content-Type content="text/html; charset=gb2312"> 
</HEAD> 
<FRAMESET id=frame border=false frameSpacing=0 rows=* 
frameBorder=0 cols=200,* scrolling="yes"> 
<FRAME name=left marginWidth=0 marginHeight=0 src="index left.php" 
scrolling=yes> 


<FRAMESET border=false frameSpacing=0 rows=53,* frameBorder=0 
cols=* scrolling="yes"> 
<FRAME name=top src="index top.php" scrolling=no> 
<FRAME name=main src="index right.php"> 


</FRAMESET> 
</FRAMESET> 


(8) 文件 fun_head.php 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 后 台 管 理 中 右 侧 页 面 中 的 头 
文件 。 具 体 代码 如 下 : 


<?php 
function head($str){ 
> 
<LINK href="Admin Style.css" rel=stylesheet> 
<STYLE type=text/css> 
-STYLE4 { 
COLOR: #000000 
3 
</STYLE> 
<BODY leftMargin=0 topMargin=0 marginheight="0" marginwidth= 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=392 rowSpan=2><img height=126 
src="image/adminmain01 .gif" width=392></TD> 
<TD vAlign=top background=image/adminmain0line2.gif height=114> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD height=20></TD></TR> 
<TR> 
<TD><SPAN class=STYLE4> 频 道 管理 中 心 </SPAN></TD></TR> 
<TR> 
<TD height=8><IMG height=1 
src="image/adminmain0line.gif" width=283></TD></TR> 
<TR> 
<TD><IMG src="image/img u.gif" 
align=absMiddle> 欢 迎 进 入 管理 <FONT 
Color=#ff0000></FONT></TD></TR> 
<TR> 
<TD><IMG src="image/img u.gif" align=absMiddle> 
<?php 
echo "当前 位 置 ， <b><font color=#ffffff>".$str."</font></b>"; 
?></TD> 
</TR> 
</TBODY></TABLE></TD></TR> 


<TR> 
<TD vAlign=bottom background=image/adminmain03.gif 
height=9><IMG height=12 src="image/adminmain02.gif" 
width=23></TD></TR></TBODY></TABLE> 
<?php 


?> 


加 
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(9) 文件 father module add.php 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 父 模块 添加 页 面 。 
具体 代码 如 下 : 


<?php 
include "session.inc"; 
include "fun head.php"; 
head (" 父 板块 添加 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
$add tag=@$ GET['add tag']; 
if ($adqd tag==1){ 
$show_ order=$ POST['show order']; 
$module name=$_ POST['module name']; 
if ($show _ order=="" or $module name==""){ 
echo "=== 对 不 起 ， 您 添加 父 板块 不 成 功 : 
<font color=red> 显 示 序 号 和 父 板块 名 称 全 不 能 为 空 </font>! 
}elsef{ 
$query="insert into father module info (module name,show order) 
values('$module name','$show order')"; 
$aa->excu ($query); 


echo "=== 恭 喜 您 ， 父 板块 添加 成 功 ! ==="; 


} 
常 泡 
<table width="100%" height="389" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
EE 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 
<form action="?add tag=1" method="post" name="forml" id="forml"> 
<table width="408" height="87" border="0" align="center" 
cellpadding="0" cellspacing="1" 
bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor="#dcccccc"> 
<td width="94" height="25" bgcolor="e0eef5"> 
<div align="right"> 显 示 序 号 :</div> 
</td> 
<td width="306" bgcolor="e0eef5"> 
<input type="text" size="6" name="show order" /> 
请 填写 一 整数 ， 如 : 1。</tad> 
</Exr> 
<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="right"> 父 板块 名 称 :</div></td> 
<td bgcolor="#FFFFFF"> 


<input type="text" size="20" name="module name" /></td> 
/二 
<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><div align="center"> 
<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; &nbsp; gnbsp; gnbsp; gnbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 
/EES 
</table> 
</form> 
<br /> 
<br /></td> 
<td width="20">gnbsp;</td> 
/ErS> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
> 


(10) 文件 father_module_bj.php 位 于 随 书 光盘 的 chl18\manage\ 下 ， 是 父 模块 编辑 页 面 。 具 


体 代码 如 下 : 


<?php 
Jnciode "seasions sinc"s 
include "fun head.php"; 
head (" 父 板块 管理 ==>> 编 辑 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
$module id=$_GET['module id']; 
$update tag=@$_ GET['update tag']; 
if ($update tag==1){ 
$show_order=$_POST['show order']; 
$module name=$ POST['module name']; 
if ($show order=="" or $module name==""){ 
echo "=== 对 不 起 ， 您 编辑 父 板块 不 成 功 : <font color=red> 
显示 序号 和 父 板 块 名 称 全 不 能 为 空 </font>! ==="; 
jelsef 
$query="update father module info set module name='$module name', 
show_order='$show order' where id='$module id'"7 
$aa->excu ($query); 


echo "=== 恭 喜 您 ， 编 辑 父 板块 添加 成 功 ! = 


select * from father module info where id='Smodule id'"7 
STSst=$Saa->excu(SquerYy) 7 
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$module=mysql fetch array(SrstvMYSQL ASSOC); 
区 > 


<table width="100%" height="389" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
Er> 


<td width="20">gnbsp;</td> 
<td valigh="top"><bre /> 


<form action="?update tag=l&module id=<?php echo $module id?>" 
method="post" name="forml" id="forml"> 


<table width="408" height="87" border="0" align="center" 
cellpadding="0" cellspacing="1" 
bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor="#dcccccc"> 
<td widt 


"94" height="25" bgcolor="e0eef5"> 
<div align="right"> 显 示 序号 :</div> 
</td> 
<td width="306" bgcolor="e0eef5"> 
<input type="text" size="6" name="show order" 
Value="<?php echo $module['show order']?>" > 
请 填写 一 整数 ， 如 : 1。</td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="right"> 父 板块 名 称 :</div></td> 
<td bgcolor="#FFFFFF"> 
<input type="text" size="20" name="module name" 


value="<?php echo $module['module name']?>" /></td> 
</tr> 


<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"> 
<div align="center"> 
<input name="submit" type="submit™" value=" 提 交 " /> 
&nbsp’; &nbsp; gnbsp; &nbsp; Enbsp; gnbsp; 


<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 


</Er 
</table> 
</form> 
<br /> 
<br /></td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
Es 


(11) 文件 father module listphp 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 父 模块 添 加 显示 页 


面 。 具 体 代 码 如 下 : 


<?php 
include "session.inc"; 
include "fun head.php"; 
head (" 父 板块 管理 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
LLL14411111 删 除 父 板块 11747714177111V11111111111111111 
$del tag=@$ GET['del tag']7 
if ($del tag==1){ 
$module id=$ GET['module id']; 
$query="delete from father module info where id='$module id'"; 
$aa->excu ($query); 


echo "== 恭 喜 您 ， 删 除 父 板块 信息 成 功 ! ==<br>"; 


/////////// 按 显示 顺序 查询 父 板块 信息 表 //ALLLAAAAAAAAAAAAAAAAA 
$query="select * from father module info order by show order"; 
$rst=$aa->excu ($query); 

人 

<table width="100%" height="390" border="0" cellpadding="0" 

cellspacing="0" bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 
<table width="80%" border="0" align="center" cellpadding: 
cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<td width="92" height="23" bgcolor="e0eef5"> 
<div align="center"> 编 号 </div></td> 
<td width="193" bgcolor="e0eef5"> 
<div align="center"> 显 示 序号 </div></td> 
<td width="368" bgcolor="e0eef5"> 
<div align="center"> 父 板块 名 称 </div></td> 
<td colspan="2" bgcolor="e0eef5"> 
<div align="center"> 操 作 </div></td> 
</Er> 

<?php 
Sm=07 
while ($module=mysql_fetch_array(Srst,MYSQL ASSOC)){ 
$m++;? 


tt 
<td height="]19" bgcolor="#FFFFFF"> 
<div align="center"><?php echo $m;?></div></td> 


且 刘 
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<td bgcolor="#FFFFFF"><div align="center"> 
<?php echo Smodule['show order']?> </div></td> 
<td bgcolor="#FFFFFF"> 
<div align="center"> 
<?php echo $module['module name']?></div></td> 
<td width="134" align="center" bgcolor="#FFFFFF"> 
<a href="father module bj.php?module 
id=<?php echo $module['id'];?>"> 编 辑 </a></td> 
<td width="142" align="center" bgcolor="#FFFFFF"> 
<a href="?del tag=1&module 
id=<?php echo $module['id']?>"> 删 除 </a></td> 
</tr> 
<?php }?> 
</table> 
</td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
> 


(12) 文件 son_module add.php 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 子 模块 添加 页 面 。 
体 代码 如 下 : 


<?php 
Fneclude "seasione inc 
include "fun head.php"; 
head (" 子 板块 添加 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
$add tag=@$ GET['add tag']; 
if ($adqd tag==1){ 
$father module id=$ POST['father module id']; 
$module name=$_ POST['module name']; 
$module cont=$ POST['module cont']; 
$user name=$ POST['user name']; 
if ($father module id=="" or $module name=="" or $module cont==""){ 
echo "=== 对 不 起 ， 您 添加 子 板块 不 成 功 ，<font color=red> 素 属 的 父 板块 、 
子 板块 的 名 称 和 简介 全 不 能 为 空 </font>! === 
}elsef{ 


$query="insert into son module info(father module id, 
module name,module cont,user name) 
values('$father module id','s$module name', 
'$module cont','S$user name')"; 
$aa->excu ($query); 


加 


echo "=== 恭 喜 您 ， 子 板块 添加 成 功 ! 


> 
<table width="100%" height="389" border= 
cellspacing="0" bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 
<form action="?add tag=1" method="post" name="forml" id="forml"> 
<table width="408" height="139" border="0" 
align="center" cellpadding="0" 
cellspacing="1" bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor: 本 人 人 人 CE 人 > 
<td width="94" height="25" bgcolor="e0eef5"> 
<div align="right"> 隶 属 的 父 板块 :</div></td> 
<td width="306" bgcolor="e0eef5"> 
<?php $bb->father module list("");?></td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="right"> 子 板块 名 称 :</div></td> 
<td bgcolor="#FFFFFF"> 
<input type="text" size="20" name="module name" /></td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" bgcolor="#FFFFFF"> 
简介 :</td> 
<td bgcolor="#FFFFFF"> 
<textarea name="module cont" cols="42" rows="3"></textarea> 
<Jtd> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" 
bgcolor="#FFFFFF"> 版 主 用 户 名 :</td> 
<td bgcolor="#FFFFFF"><input type="text" size="20" name="user name" /> 
可 不 填 。</ta> 
En 
<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><div align="center"> 
<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; &nbsp; gnbsp; tnbsp; gnbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 
</Er> 
</table> 
</form> 
be > 
<br /></td> 


0" cellpadding="0" 
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<td width="20">gnbsp;</td> 
i 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
> 


(13) 文件 sonr_module_bj.php 位 于 随 书 光盘 的 chl18\manage\ 下 ， 是 子 模块 编辑 页 面 。 
代码 如 下 : 


<?php 
include "session.inc"; 
include "fun head.php"; 
head (" 子 板块 管理 >> 编 辑 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
$module id=$_ GET['module id']; 
$update tag=@$ GET['update tag']; 
if ($update tag==1){ 
$father module id=$ POST['father module id']; 
$module name=$ POST['module name']; 
$module cont=$ POST['module cont']; 
$user name=$ POST['user name']; 
if ($father module id=="" or $module name=="" or $module cont==""){ 
echo "=== 对 不 起 ， 您 编辑 子 板块 不 成 功 ，<font color=red> 隶 属 的 父 板块 、 
子 板块 的 名 称 和 简介 全 不 能 为 空 </font>! ==="; 
}elsef{ 
$query="update son module info 
set father module id='$father module id',module_ 
name="' $module name',module cont='$module cont', 
user name='$user name' where id='$module id'"7 
$aa->excu ($query); 


echo "=== 恭 喜 您 ， 编 辑 子 板块 添加 成 功 ! == 


$query="select * from son module _ info where id='$module id'"7 
$rst=$aa->excu ($query); 
$module=mysql fetch array($rst,MYSQL ASSOC); 
2 
<table width="100%" height="389" border="0" cellpadding="0" 
cellspacing="0" bgcolor="f0f0f0"> 
<tbody> 
EE 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 


<form action="?update tag=1&module id=<?php echo $module id?>" 
method="post" name="forml" id="forml"> 
<table width="408" height="139" border="0" align="center™" 
cellpadding: " cellspacing="1" 
bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor="#dcccccc"> 
<td width="94" height="25" bgcolor="e0eef5"><div align="right"> 
隶属 的 父 板块 :</div></td> 
<td width="306" bgcolor="e0eef5"> 
<?php $bb->father _ module list($module['father module id']);?> 


</td> 
HErS 
<tr bgcolor="#dddddd"> 
<td heigh 25" bgcolor="#FFFFFF"> 


<div align="right"> 子 板块 名 称 :</div></td> 
<td bgcolor="#FFFFFF"> 
<input type="text" size="20" name="module name" 
Value="<?php echo $module['module name']?>" /></td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" 
bgcolor="#FFFFFF"> 简 介 :</td> 
<td bgcolor="#FFFFFF"> 
<textarea name="module cont" cols="42" rows="3"> 
<?php echo $module['module cont']?></textarea></td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle™" 
bgcolor="#FFFFFF"> 版 主 用 户 名 :</td> 
<td bgcolor="#FFFFFF"><input type="text" size="20" 
name="user name" value="<?php echo $module['user name']?>" A 
可 不 填 。</td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><div align="center"> 
<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; &nbsp; gnbsp; gnbsp; &nbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 
</Er> 
</table> 
</form><br /> 
<br /></td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
2 
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(14) 文件 son_module listphp 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 子 模块 显示 页 面 。 具 体 
代码 如 下 : 


<?php 

include "session.inc"7 

include "fun head.php"; 

head (" 子 板块 管理 ") ; 

include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 


$bb=new myfunction; 

$aa->link(""); 

L114LLL11171 删 除 子 板块 11777747VVV111111111111111111111 

$del tag=@$ GET['del tag']; 

if ($del tag==1){ 
$module id=$ GET['module id']; 
$query="delete from son module info where id='$module id'"7 
$aa->excu ($query); 


echo "== 蕉 喜 您 ， 删 除 子 板块 信息 成 功 ! ==<br>"; 


/111111111111111111 按 显示 顺序 查询 父 板块 信息 表 / 1/171111117/ 
$query="select * from father module info order by show order"; 
$rst=$aa->excu ($query); 
2 
<table width="100%" height="390" border= 
bgcolor="f0f0f0"> 
<tbody> 
芭 瑟 > 
<td width="20">&nbsp;</td> 
<td valign="top"><br /><table width="80%" border="0" align="center" 
cellpadding="0" cellspacing="1" bgcolor="449ae8"> 
<tr bgcolo Oocoo"> 
<td width="74" height="23" bgcolor="e0eef5"> 
<div align="center"> 显 示 序号 </div></td> 
<td width="84" bgcolor="e0eef5"> 
<div align="center"> 父 板块 名 称 </div></td> 
<td width="410" bgcolor="e0eef5"> 
<div align="center"> 子 板块 名 称 </div></td> 
<td colspan="2" bgcolor="e0eef5"> 
<div align="center"> 操 作 </div></td> 
</tr> 
<?php 
while ($father module=mysql fetch array($rst,MYSQL ASSOC)){ 
?> 


0" cellpadding="0" cellspacing="0" 


<tr> 
<td height="19" bgcolor="#FFFFFF"><div align="center"> 
<?2php echo $father module['show order']?></div></td> 
<td colspan="4" align="left" valign="middle" bgcolor="#CCCCCC"> 
<?php echo $father module['module name']?></td> 
</tr> 


<?php 
/1/1/1111/ 从 子 板块 信息 表 中 按 id 顺序 查询 隶属 该 父 板块 的 子 板块 的 信息 /7/11/11111111/ 
$query="select * from son module info 
where father module id="'" .$father module['id']."" 
order by id"7 
$rst2=$aa->excu ($query); 
$m=0; 
while($son module=mysql fetch array($rst2,MYSQL ASSOC)){ 
Sm++7 
二 
<tr> 
<td height="19" bgcolor="#FFFFFF">&nbsp;</td> 
<td align="center" valign="middle" bgcolor="#FFFFFF"> 
<?php echo $m?></td> 
<td bgcolor="#FFFFFF"><?php echo $son module['module name']?></td> 
<td width="80" align="center" bgcolor="#FFFFFF"> 
<a href="son module bj.php?module_ 
id=<?php echo $son module['id'];?>" > 编辑 </a></td> 
<td width="80" align="center" bgcolor="#FFFFFF"> 
<a href="?del tag= lg&gmodule_ 
id=<?php echo $son module ['id']?>"> 删 除 </a></td> 


<?php }?> 
</tr> 
<?php }?> 
</table> 
</td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
受 全 


(15) 文件 user listphp 位 于 随 书 光盘 的 chl8\manage\ 下 ， 


码 如 下 : 


<?php 

include "session.inc"; 

include "fun head.php"; 

head ("所 有 用 户 "); 

include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 

$bb=new myfunction; 
$aa->link(""); 


是 显示 所 有 用 户 的 页 面 。 具 体 代 


A1111111111 删 除 注册 用 户 17777VVVVVVV11111111111111111111 


$del tag=@$ GET[del tag]; 


$user id=@$ GET[user id]; 
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$query="delete from user info where id='$user id'"7 
$aa->excu ($query); 
echo "== 恭 喜 您 ， 删 除 注册 用 户 信息 成 功 ! ==<br>"; 
/1111111111111/ 从 用 户 信息 表 中 查询 所 有 用 户 /11111111111111111 
$query="select * from user info order by id desc"; 
<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
六 全 下 六 
<td width: 0">gnbsp;</td> 
<td valign="top"><br /> 
<table width="80%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td height="30" align="left" valign="middle"> 
<?php $bb->page ($query,@$page id,@$add,20)?></td> 
</Er> 
</table> 
<table width="80%" border="0" align="center" cellpadding="0" 
cellspacing="1" bgcolor="449ae8"> 
HocCGG0G"> 
<td width="46" height="23" bgcolor="e0eef5"> 
<div align="center"> 序 号 </div></td> 
<td width="213"” bgcolor="e0eef5"> 
<div align="center"> 用 户 名 </div></td> 
<td width="201" bgcolor="e0eef5"> 
<div align="center"> 注 册 时 间 </div></td> 
<td width="188" bgcolor="e0eef5"> 
<div align="center"> 最 后 登录 时 间 </div></td> 
<td width="80" bgcolor="e0eef5"><div align="center"> 操 作 </div></td> 


</tr> 
<?php 
$rst=$aa->excu ($query); 
$m=0; 
while($user=mysql fetch array($rst,MYSQL ASSOC)){ 
$m++? 


2 
<td height="19" bgcolor="#FFFFFF"> 
<div align="center"><?php echo @$m;?></div></td> 
<td bgcolor="#FFFFFF"> 
<div align="center"><?php echo $user['user name']?></div></td> 
<td bgcolor="#FFFFFF"> 
<div align="center"><?php echo $user['timel']?></div></td> 
<td align="center" bgcolor="#FFFFFF"> 
<?php echo $user['time2']?></td> 
<td align="center™" bgcolor="#FFFFFF"> 
<a href="?del tag=l&user 


国语 


id=<?php echo S$user['id']?>"> 删 除 </a></td> 
本 
<2php }?> 
</table> 
<table width="80%" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
EE 
<td height="30" align="right" valign="middle"> 
<?php 
$query="select * from user info order by id desc"; 
$bb->page ($query, @$page_ id,@$add, 20); 
?></td> 
</tr> 
</table></td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
Ee 


(16) 文件 user js.php 位 于 随 书 光盘 的 ch18manage\ 下 ， 是 用 户 的 检索 页 面 。 具 体 代码 如 下 : 


<?php 
Jnclude “sessions nc 
include "fun head.php"; 
head ("用 户 检索 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
LUVL44VVM1M1 删 除 用 户 174VV477V7V4111111111111111111171 
$del tag=@$ GET[del tag]; 
if ($del tag==1){ 
$del id=@$ GET[del id]; 
$query="delete from user info where id='".$del id."'"; 
$aa->excu ($query); 


echo "== 蕉 喜 您 ， 删 除 用 户 信息 成 功 ， 请 继续 ! ==<br>"; 
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$user name=@$ POST[user name]; 
党 过 
<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
Er 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 
<table width="70%" border="0" align="center" cellpadding="0" 
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cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<form id="forml" name="forml" method="post" action="?"> 
<td height="23" bgcolor="e0eef5"> 
<div align="center"> 
<input type="text" name="user name" size="16" 
value="<?php echo $user name?>" />&gnbsp;&nbsp;&nbsp; gnbsp; 
<input type="submit" name="Submit" value=" 提 交 " /> 
</div></td> 
</form> 
/EE 
< 
<td height="19"” align="center" bgcolor="#FFFFFF"> 


echo "请 输入 您 要 检索 的 用 户 名 ， 点 提交 查询 ! "; 
jelsef 
$query="select * from user info where user name='$user name'™"; 
$rst=$aa->excu ($query); 
if (mysql num rows($rst)==0){ 
echo "很 抱歉 ， 系 统 没有 检索 到 您 要 查找 的 用 户 ! "; 
jelset 
$user=mysql fetch array($rst,MYSQL ASSOC); 


?> 
<table width="100%" border="0" cellspacing="2" cellpadding="0"> 
<tr> 

<td width="29%" height="20" align="right" bgcolor="#dddddd"> 


用 户 名 :</td> 
<td width="71%" align="left" bgcolor="#dddddd"> 
<?php echo $user['user name']?></td> 
</tr> 
<Er> 
<td height="20" align="right" bgcolor="#dddddd"> 登 录 口 令 :</td> 
<td align="left" bgcolor="#dddddd"> 
<?php echo $user['user pw']?></td> 
xr 
<tr> 
<td height="20" align="right" bgcolor="#dddddd"> 注 册 时 间 :</td> 
<td align="left" bgcolor="#dddddd"> 
<?php echo $user['timel']?></td> 
</Er> 
ER 
<td height="20" align="right" bgcolor="#dddddd"> 
最 后 登录 时 间 :</td> 
<td align="left”bgcolor="#dddddd"> 
<?php echo $user['time2']?></td> 
</tr> 
<tr> 
<td height="20" colspan="2" align="center" bgcolor="#dddddd"> 
<a href=?del tag=l&del id=<?php echo $user['id']?>> 


日 
第 图 
删除 此 用 户 </a></ta> 
</tr> 章 
</table> 
<?php 本 
} 从 
} 坛 
</td> 
</tr> 
</table> 
</td> 
<td width="20">gnbsp;</td> 


</tr> 
</tbody> 
</table> 
<?php 


include "bottom.php"; NN 
?> SS 
页 NN 


(17) 文件 user pw_change.php 位 于 随 书 光盘 的 chl8\manage\ 下 ， 是 管理 员 密 码 修 改 
具体 代码 如 下 : 


<?php 
include "session.inc"; 
include "fun head.php"; 
head ("密码 更 改 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysql; 
$bb=new myfunction; 
$aa->link(""); 
LMM1414M111M/ 更 改 密码 /V4W4711111111111111111111111111 
$tijiao=$_ POST[tijiao]; 
if ($tijiao==" 提 交 "){ 
$pw_old=$_POST[pw_old]; 
$pw_newl=$_POST[pw_ newl]; 
$pw_new2=$_POST[pw_ new2]; 
if ($pw_newl!=$pw_ new2){ 
echo "=== 您 两 次 输入 的 新 密码 不 一 致 , 请 重新 输入 !==="; 
}elsef{f 
$query="select * from manage user info where user 
name='$ SESSION [manage name]' and user pw='$pw old'"; 
$rst=$aa->excu ($query); 
if (mysql num rows($rst)==0){ 
echo "=== 您 输入 的 旧 密 码 不 正确 , 请 重新 输入 !=="; 
jelsef 
$query="update manage user info set user pw="'$pw_ newl' 
where user name='$ SESSION [manage name]'™"; 
$aa->excu ($query); 


echo "=== 基 喜 您 ,您 的 登录 密码 修改 成 功 !==="; 
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re 
<table width="100%" height="390" border= 
bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 
<form id="forml" name="forml" method="post" action="#"> 
<table width="60%" border="0" align="center" cellpadding: 
cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<td width="27%" height="23" align="right" bgcolor="e0eef5"> 
用 户 名 :</td> 
<td width="73%" align="left" bgcolor="e0eef5"> 
<?php echo $_ SESSION [manage_name]?></td> 
</tr> 
RE 
<td height="19"” align="right" bgcolor="#FFFFFF"> 原 口令 :</td> 
<td align="left" bgcolor="#FFFFFF"> 
<input type="text" name="pw old" size="16" /></td> 
</tr> 
<tr> 
<td height="19" align="right" bgcolor="#FFFFFF"> 新 密码 :</td> 
<td align="left" bgcolor="#FFFFFF"> 
<input type="text" name="pw_newl" size="16" /></td> 
</tr> 
EE 
<td height="19" align="right" bgcolor="#FFFFFF"> 再 次 新 密码 :</td> 
<td align="left" bgcolor="#FFFFFF"> 
<input type="text" name="pw_new2" size="16" /></td> 
/tr> 
人 
<td height="19" colspan="2" align="center" bgcolor="#FFFFFF"> 
<input type="submit" name="tijiao" value=" 提 交 " /> 
&nbsp; gnbsp; gnbsp; 
<input type="reset" name="Submit2" value=" 重 置 " /></td> 
</tr> 
</table> 
</form> 
</td> 
<td width="20">gnbsp;</td> 
<VEE> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 


0" cellpadding="0" cellspacing="0" 


?> 


成 功 登 录 到 网 站 后 台 管理 系统 的 效果 如 图 18-9 所 示 。 


本 管理 模块 共 分 四 个 子 模块 : 父 模块 添加 、 父 模块 管 
理 、 子 模块 添加 、 子 模块 管理 。 其 中 父 模块 添加 和 子 模块 


添加 可 以 实现 本 论坛 的 父 模块 和 子 模块 的 添加 ; 父 模块 的 
管理 和 子 模块 的 管理 可 以 实现 本 论坛 父 模块 和 子 模块 的 删 
除 、 蝙 同等 功能 


本 管理 模块 共 分 两 个 子 模 块 ;所 有 用 户 和 用 户 检索 。 其 
中 所 有 用 户 按 用 户 注册 的 先后 顺序 分 页 依次 列 出 。 用 户 检 
素 是 由 管理 员 输入 要 查询 的 论坛 注册 用 户 的 用 户 名 ,系统 
通过 数据 库 查 询 出 该 用 户 的 相关 信息 ， 并 列 出 ， 而 且 管理 
员 也 可 以 在 查询 注册 用 户 后 直接 册 除 该 用 户 。 
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本 管理 模块 共 分 两 个 子 模 块 :密码 更 改 和 帖子 管理 其 本 模块 提供 了 本 论坛 的 版 本 号 、 版 权 所 有 、 设 计 制 作 
中 密码 更 改 提供 了 管理 员 更 改 闭 码 的 功能 ,但 必须 输入 原 以 及 技术 支持 等 信息 。 
密码 和 两 次 新 密码 ; 帖子 管理 是 直接 进入 论坛 的 主 界面 ， 
但 与 普通 注册 用 户 所 不 同 的 是 ， 在 论坛 的 每 个 发 帖 和 回复 
后 面 都 多 了 一 个 如 除 控 钮 可 以 通过 此 的 钮 名 除 相关 帖子 
或 回复 . 


GG 


图 18-9 ”后 台 管理 系统 主页 面 


单 击 页 面 左 侧 的 “论坛 板块 管理 ”选项 ， 即 可 在 展开 的 列表 中 ， 查 看 板块 管理 操作 ， 如 
图 18-10 所 示 。 


论坛 板块 管理 区 
父 板块 管理 
子 板块 添加 
子 板块 管理 


18-10 “论坛 板块 管理 ”列表 


单 击 “ 父 板块 添加 ”选项 ， 即 可 在 右 侧 的 窗口 中 输入 显示 序号 和 父 板块 名 称 ， 然 后 单 击 
“提交 ”按钮 ， 如 图 18-11 所 示 。 


显示 序号 :|1 请 填写 一 整数 , 如 : 1 。 


父 板块 名 称 :| 拼 届 


轨 时 


18-11 添加 父 板块 
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PHP+MySQL 动 态 网 站 开发 
pdt 汪 全 前 汪 大 二 Ra 


添加 成 功 后 ， 即 可 显示 成 功 提示 信息 ， 如 图 18-12 所 示 。 


-=== 苦 喜 您 ， 添 加 父 板块 添加 成 功 t === 


显示 序号 : 请 填写 一 整数 ,如 : 1 。 
父 板块 名 称 :| 


本 ” E 


图 18-12 添加 父 板块 的 成 功 提示 信息 
刷新 论坛 的 主页 面 ， 即 可 看 到 新 添加 的 父 板块 ， 如 图 18-13 所 示 。 


18-13 ”查看 父 板块 


在 后 台 管理 主页 面 的 “论坛 板块 管理 ”列表 中 ， 单 击 “ 父 板块 管理 ”选项 ， 即 可 进入 父 
板块 管理 页 面 中 ， 如 图 18-14 所 示 。 用 户 可 以 编辑 和 删除 存在 的 父 板块 。 


18-14 ”编辑 父 板块 
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在 后 台 管理 主页 面 的 “论坛 板块 管理 ”列表 中 ， 单 击 “ 子 板块 添加 ”选项 ， 即 可 进入 子 
板块 添加 页 面 ， 如 图 18-15 所 示 。 用 户 输入 相关 信息 后 ， 单 击 “ 提 交 ” 按 钮 即 可 。 
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图 18-15 添加 子 版 块 
刷新 论坛 的 主页 面 ， 即 可 看 到 新 添加 的 子 板块 ， 如 图 18-16 所 示 。 


贴 子 总 数 : 0 会 员 总 数 : 1 欢迎 新 会 员 : aaa 


北京 到 郑州 拼车 
国 尖 人 二 
18-16 ”查看 添加 的 子 板块 


单 击 页 面 左 侧 的 “论坛 用 户 管理 ”选项 ， 即 可 在 展开 的 列表 中 ， 查 看 用 户 管理 操作 ， 如 
图 18-17 所 示 。 


18-17 “论坛 用 户 管理 ”列表 
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单 击 “ 所 有 用 户 ”选项 ， 即 可 在 右 侧 的 窗口 中 查看 论坛 的 用 户 ， 如 图 18-18 所 示 。 


[下 一 页 第 1 页 , 共 ! 页 


序号 用 户 名 注册 时 间 
1 


最 后 登录 时 间 。 | 操作 


2012-10-17 
lz012-10-08 04:11:28| 
02:58:01 


[下 一 页 第 1 页 , 共 ! 页 


18-18 “所 有 用 户 ” 页 面 


在 后 台 管 理 主页 面 的 “用 户 板块 管理 ”列表 中 ， 单 击 “ 用 户 检索 ”选项 ， 进 入 用 户 检索 
页 面 ， 输 入 用 户 名 后 ， 单 击 “ 提 交 ” 按 钮 ， 即 可 显示 用 户 的 具体 信息 ， 如 图 18-19 所 示 。 


风电 全 各 昌 和 从 
加 [E 
用 户 名 ; saa 
登录 口令 : 123456 


注册 时 间 ; 2012-10-08 04:11:28 
最 后 登录 时 间 : 2012-10-17 02:58:01 
删除 此 用 户 


18-19 用 户 检索 页 面 


在 后 台 管 理 主页 面 中 ， 单 击 页 面 左 侧 的 “安全 管理 ”选项 ， 即 可 在 展开 的 列表 中 管理 密 
码 和 帖子 操作 ， 如 图 18-20 所 示 。 


单 击 “ 密 码 更 改 ” 选 项 ， 即 可 在 右 侧 的 页 面 中 修改 用 户 的 密码 ， 如 图 18-21 所 示 
用 户 名 :| aaa 


安全 管理 加 id 
二 放生 
帖子 管理 


图 18-20 “安全 管理 ”列表 
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18-21 更改 用 户 密码 
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